Excelize は、純粋な Go で記述されたライブラリで、XLAM / XLSM / XLSX / XLTM / XLTX ファイルの読み書きを可能にする一連の関数を提供します。Microsoft Excel™ 2007 以降で生成されたスプレッドシートドキュメントの読み取りと書き込みをサポートします。高い互換性により複雑なコンポーネントをサポートし、大量のデータを含むワークシートからデータを生成または読み取るためのストリーミング API を提供します。このライブラリには Go バージョン 1.18 以降が必要です。
場合によっては、既存の Excel ドキュメントコンテンツの読み込み、新しい Excel ドキュメントの作成、既存のドキュメント(テンプレート)に基づく新しい Excel ドキュメントの生成、Excel ドキュメントへのイメージの挿入、チャートなどの Excel ドキュメントをプログラムで操作する必要があります。 テーブルなどの要素。プラットフォーム間でこれらの操作を実装する必要がある場合があります。Excelize はこれらのニーズを容易に満たすことができます。
オープンソース
GitHub: github.com/xuri/excelize
ドキュメントリファレンス: xuri.me/excelize/ja
リリースノート
このバージョンでの最も注目すべき変更点は次のとおりです:
互換性のヒント
- アップグレード要件 Go 言語バージョンは 1.18 以降、依存関係パッケージ XXX のアップグレード用
golang.org/x/net
-
HeaderFooterOptions
構造体フィールドのAlignWithMargins
およびScaleWithDoc
のデータ型をポインターとして変更します - 未使用のエクスポートされたデータ構造
ShapeColor
を削除します
新機能
- 新しいエクスポート関数
SetCellUint
を追加 - すべての画像セルを取得するための新しいエクスポート関数
GetPictureCells
を追加 - 条件付き書式スタイル定義を取得するための新しいエクスポート関数
GetConditionalStyle
を追加 - ワークシートのヘッダーとフッターを取得するための新しいエクスポート関数
GetHeaderFooter
を追加 - テーブルとピボットテーブルのスライサーを追加するための新しいエクスポート関数
AddSlicer
を追加 - ピボット テーブルを取得するための新しいエクスポート関数
GetPivotTables
を追加 - ピボット テーブルを削除するための新しいエクスポート関数
DeletePivotTable
を追加 - ピボット テーブル名の指定をサポートするために、
PivotTableOptions
に新しいName
フィールドを追加します - 新たに 7 個の数式関数をサポート: DBCS, SEARCH, SEARCHB, TEXT, TEXTAFTER, TEXTBEFORE と xlfn.ANCHORARRAY
- グラフの線の種類を指定するためのエクスポート
ChartLineType
列挙を追加します -
Chart
データ型に新しいBorder
フィールドを追加して、グラフ領域の境界線を設定します - 線の種類を設定するために、
ChartLine
タイプに新しいType
フィールドを追加します - 新しいエクスポートされたソース関係と名前空間
NameSpaceSpreadSheetXR10
,ContentTypeSlicer
,ContentTypeSlicerCache
, およびSourceRelationshipSlicer
を追加します - 新しいエクスポートされた拡張 URI
ExtURIPivotCacheDefinition
を追加します - 定義名、テーブル名、またはピボット テーブル名にドット文字を使用できるようにする
- テーブルを削除するときにテーブル範囲内のすべてのセルの値を保持する
- 分数形式コードを使用したセル値の形式のサポート
- 生成されるワークブックのサイズを削減し、潜在的なセキュリティ問題を解決するために、画像を削除するときに内部的にワークブックから画像ファイルを削除することをサポートします
- コメントボックスの高さと幅の設定をサポート
- 条件付き書式設定、データ検証、定義名、描画オブジェクト、数式参照、列/行の挿入/削除に関する揮発性依存関係の更新をサポートします
- 6 種類の新しい条件付き書式設定タイプをサポート: テキスト、空白、空白なし、エラー、エラーなし、期間
- 複数のダッシュ算術記号を使用した式の計算をサポート
- コピー条件付きフォーマットと重複行のデータ検証をサポート
-
SetRowHeight
関数を使用するときに高さの値が -1 の場合、カスタム行の高さの設定解除をサポートします - 無効な行の高さの値が指定された場合
SetRowHeight
関数はエラーを返します -
AddChart
関数は、グラフのデータ ラベルの位置の設定をサポートします -
AddChart
関数は、チャート領域、プロット領域、メーカーの単色または透明な塗りつぶしの設定をサポートし、Chart
、ChartPlotArea
、およびChartMarker
データ型に新しいフィールドFill
を追加します -
AddChart
関数は、チャート軸のフォントファミリー、サイズ、およびストライクスタイルの設定をサポートします -
ChartSeries
データ型に新しいフィールドDataLabelPosition
を追加し、グラフ シリーズ データ ラベルの位置の設定をサポートします -
Chart
データ型に新しいフィールドBubbleSize
を追加し、バブル チャートまたは 3D バブル チャートのすべてのデータ シリーズでのバブル サイズの設定をサポートします - 新しいエクスポート
ChartDataLabelPositionType
データ タイプを追加 -
GetPictureCells
およびGetPictures
関数は、Kingsoft WPS™ Office によって作成された埋め込みセル画像の取得をサポートしています -
SetConditionalFormat
関数は、複数のセル範囲を使用した条件付き書式設定をサポートします - ワークシートの名前を変更するときに、定義された名前の参照を更新するサポート
- 新しい
GetBaseColor
関数のサポートを追加して、優先される 16 進カラー コードを取得します - 計算エンジンは日付と数式タイプのセルをサポートします
- セル値読み取り関数は、
OpenReader
のOptions
設定を継承します
互換性を向上させる
- 絶対パス描画部分の互換性を向上
- ワークブックの内部タブ比率プロパティ値の互換性を向上
- 空のカスタム数値形式コードとの互換性を向上
- デフォルトのテーマパーツ名前空間をサポートしていないビューアとの互換性を向上させます
- 削除セルのコメント形状の KingSoft WPS™ Office との互換性を向上
- ソートされた内部パーツパスを使用してワークブックを保存すると、同一に作成されたワークブックのハッシュチェックサムが同じになります
問題の修正
- MID および MIDB 数式関数の num_chars 引数のチェックを追加し、負の数を指定した場合のパニックを防止します
- LEN, LOWER, PROPER, REPT, UPPER, IF 数式関数で数値引数を使用した空の計算結果を修正しました
- 場合によっては数式計算関数 CHITEST および MMULT がパニックになる問題を修正
- v2.8.0 の回帰バグ、印刷領域の設定に関するエラー、および組み込みの特別に定義された名前を使用したタイトルの印刷を修正しました
- v2.8.0 の回帰バグ、内部インデックス付きカラーおよび MRU カラー スタイル パーツとの互換性を向上させることによって生成された破損したワークブックを修正しました
- v2.8.0 のリグレッションバグを修正。数値形式コードの適用結果が空だった
- v2.7.1 回帰バグを修正。バブルまたは 3D バブル チャートでバブルが非表示になる
- ローカルシート ID に nil ポインタガードを追加することで
AutoFilter
のパニックを修正しました - 場合によってはテーブルを追加するときに生成される破損したワークブックを修正
- 不正な時刻数値形式の結果を修正
- 数式文字列セル値の取得をサポート
- 単一のテーブルセルを含むワークブックで生成される誤ったテーブル ID を修正
- 場合によってはコンテンツ タイプで欠落している関係部分を修正
- 場合によっては不足しているリテラル トークンを修正するために数値形式パーサーをアップグレードします
- 組み込みの zh-cn および zh-tw 言語の数値形式を更新
- 割り当てられた間違ったカスタム数値形式 ID を修正する
- テーブルの範囲を削除して再度作成することによる更新が機能しない問題を修正しました
- ストリーム リーダーの一時ファイルをクリアできないという潜在的な問題を修正
- 数式の計算結果が正しくない場合があるのを修正
- セル値の取得時の同時実行競合状態を修正
- スタイル定義の取得時に欠落しているいくつかの形式を修正
- 数値形式の科学表記法のゼロフィルの問題を修正
-
r
属性のない内部行要素を持つワークブックの読み取り時のパニックを修正 - インラインリッチテキストセルの取得時に
GetCellRichText
がエラーを返す問題を修正 - 場合によっては設定されたセル値の無効な共有文字列テーブル インデックスを修正
- 平均以上のルールを持たない条件付きフォーマットを取得する際の
GetConditionalFormats
パニックを修正 - 行の削除時にマージされたセルを誤って調整する問題を修正
-
SetConditionalFormat
関数が誤った複数の条件付きフォーマット ルールの優先順位を作成する問題を修正しました -
GetConditionalFormats
関数がグラデーション データ バー ルールを返さない問題を修正しました - 間違った
DecimalPlaces
フィールド値を返すようにGetStyle
またはGetConditionalStyle
関数を修正しました -
RawCellValue
を有効にすると、CalcCellValue
関数が生の値を返さない問題を修正しました
パフォーマンスの最適化
- ピボットテーブルと画像の追加と削除のパフォーマンスが向上しました
- 行とセルをトリミングしてメモリ消費を削減します
その他
- Go Modules はモジュールの更新に依存しています
- 単体テストとドキュメントの更新
- 簡体字中国語、英語、フランス語、ロシア語、日本語、韓国語、アラビア語、ドイツ語、スペイン語を含む多言語ドキュメントサイトの更新
- Slack、Telegram 群组 チャンネルに参加して、コミュニティの他のメンバーに会いにようこそ