1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

記事投稿キャンペーン 「2024年!初アウトプットをしよう」

EPPlus4.5.3.3 にてDrawings.xmlが自動でインデントされてしまう問題について

Posted at

記事タイトルの内容で困ったのでメモと情報共有代わりに残します。
(更新の凍結したOSSを使う人間が私以外にいるかは不明ですが……)

問題

  • EPPlus4.5.3.3(以下EPPlus)を使用した時、吹き出し、図形内にスペースを使うと自動で改行されてしまう。

対策

上記の問題はEPPlusのExcelDrawings.cs内のExcelDrawingsクラスのConstructor内の記述に、

_drawingsXml.PreserveWhitespace = false;

と記載されている事が原因でした。

これをtrueに変更すると自動で改行されなくなります。

詳細

PreserveWhitespaceは要素のコンテンツにある空白を保存するかどうかを示す値の取得設定をするプロパティです。1

読み込み時

true:空白は保存される。
false:重要な空白だけが保存される。

保存時

true:ドキュメント内の空白は出力でも保存される。
false:出力に自動的にインデントを設定して保存する。

その為、ExcelDrawingsでPreserveWhitespaceがfalseだと、空白を消去され、xmlが整理(インデント、改行などが自動で設定)されてしまいます。

この変更をする事で何処かしらでエラーが起きるかもしれませんが、今のところは発生していません。
(気づいていないだけかも……)

  1. https://learn.microsoft.com/ja-jp/dotnet/api/system.xml.xmldocument.preservewhitespace?view=net-8.0

1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?