Excelizeの概要
Excelizeは、Go言語で書かれたOffice Excelドキュメントを操作するための基本ライブラリであり、国際基準であるECMA-376およびISO/IEC 29500に基づいています。これは、Microsoft Excel™ 2007およびそれ以降で作成されたスプレッドシートドキュメントの読み込みや書き込みをサポートし、XLAM / XLSM / XLSX / XLTM / XLTXなどのさまざまなドキュメント形式をサポートしています。また、スタイル、画像(テーブル)、ピボットテーブル、スライサーなどの複雑なコンポーネントを含むドキュメントと高い互換性があり、大規模なデータを処理するためのストリーミング読み書きAPIを提供しています。さまざまなレポートプラットフォーム、クラウドコンピューティング、エッジコンピューティング、およびその他のシステムに適用できます。これを使用するためには、Go言語のバージョン1.16以上が必要です。
インストール
以下の表には、異なるバージョンのGo言語に対するExcelize基本ライブラリの最小要件が示されています。
Excelizeのバージョン | Go言語の最小要件 |
---|---|
v2.7.0 | 1.16 |
v2.4.0 ~ v2.6.1 | 1.15 |
v2.0.2 ~ v2.3.2 | 1.10 |
v1.0.0 ~ v2.0.1 | 1.6 |
最新バージョンのExcelizeを使用するには、Go言語のバージョン1.16以上が必要です。Go 1.21.0には互換性のない変更があり、これによりExcelize基本ライブラリがこのバージョンで正常に動作しなくなります。Go 1.21.xを使用している場合は、Go 1.21.1以上にアップグレードしてください。
- インストールコマンド
go get github.com/xuri/excelize
- パッケージを管理するためにGo Modulesを使用している場合は、次のコマンドを使用して最新バージョンをインストールします。
go get github.com/xuri/excelize/v2
アップデート
- アップデートコマンド
go get -u github.com/xuri/excelize/v2
Excelドキュメントの作成
以下は、Excelドキュメントを作成するための簡単な例です。
package main
import (
"fmt"
"github.com/xuri/excelize/v2"
)
func main() {
f := excelize.NewFile()
defer func() {
if err := f.Close(); err != nil {
fmt.Println(err)
}
}()
// 新しいシートを作成
index, err := f.NewSheet("Sheet2")
if err != nil {
fmt.Println(err)
return
}
// セルの値を設定
f.SetCellValue("Sheet2", "A2", "Hello world.")
f.SetCellValue("Sheet1", "B2", 100)
// ワークブックのデフォルトワークシートを設定
f.SetActiveSheet(index)
// ファイルを指定したパスに保存
if err := f.SaveAs("Book1.xlsx"); err != nil {
fmt.Println(err)
}
}
Excelドキュメントの読み込み
以下は、Excelドキュメントを読み込む例です。
package main
import (
"fmt"
"github.com/xuri/excelize/v2"
)
func main() {
f, err := excelize.OpenFile("Book1.xlsx")
if err != nil {
fmt.Println(err)
return
}
defer func() {
if err := f.Close(); err != nil {
fmt.Println(err)
}
}()
// ワークシート内の指定されたセルの値を取得
cell, err := f.GetCellValue("Sheet1", "B2")
if err != nil {
fmt.Println(err)
return
}
fmt.Println(cell)
// Sheet1のすべてのセルを取得
rows, err := f.GetRows("Sheet1")
if err != nil {
fmt.Println(err)
return
}
for _, row := range rows {
for _, colCell := range row {
fmt.Print(colCell, "\t")
}
fmt.Println()
}
}
Excel文書でのグラフの作成
Excelizeを使用して、わずか数行のコードでグラフを作成するのは非常に簡単です。ワークシートの既存のデータに基づいてグラフを作成したり、ワークシートにデータを追加してからグラフを作成したりすることができます。
package main
import (
"fmt"
"github.com/xuri/excelize/v2"
)
func main() {
f := excelize.NewFile()
defer func() {
if err := f.Close(); err != nil {
fmt.Println(err)
}
}()
for idx, row := range [][]interface{}{
{nil, "Apple", "Orange", "Pear"}, {"Small", 2, 3, 3},
{"Normal", 5, 2, 4}, {"Large", 6, 7, 8},
} {
cell, err := excelize.CoordinatesToCellName(1, idx+1)
if err != nil {
fmt.Println(err)
return
}
f.SetSheetRow("Sheet1", cell, &row)
}
if err := f.AddChart("Sheet1", "E1", &excelize.Chart{
Type: excelize.Col3DClustered,
Series: []excelize.ChartSeries{
{
Name: "Sheet1!$A$2",
Categories: "Sheet1!$B$1:$D$1",
Values: "Sheet1!$B$2:$D$2",
},
{
Name: "Sheet1!$A$3",
Categories: "Sheet1!$B$1:$D$1",
Values: "Sheet1!$B$3:$D$3",
},
{
Name: "Sheet1!$A$4",
Categories: "Sheet1!$B$1:$D$1",
Values: "Sheet1!$B$4:$D$4",
}},
Title: []excelize.RichTextRun{
{
Text: "Fruit 3D Clustered Column Chart",
},
},
}); err != nil {
fmt.Println(err)
return
}
// ファイルを指定されたパスに保存
if err := f.SaveAs("Book1.xlsx"); err != nil {
fmt.Println(err)
}
}
Excel文書に画像を挿入する
package main
import (
"fmt"
_ "image/gif"
_ "image/jpeg"
_ "image/png"
"github.com/xuri/excelize/v2"
)
func main() {
f, err := excelize.OpenFile("Book1.xlsx")
if err != nil {
fmt.Println(err)
return
}
defer func() {
if err := f.Close(); err != nil {
fmt.Println(err)
}
}()
// 画像を挿入
if err := f.AddPicture("Sheet1", "A2", "image.png", nil); err != nil {
fmt.Println(err)
return
}
// ワークシートに画像を挿入し、画像のスケールを設定します
if err := f.AddPicture("Sheet1", "D2", "image.jpg",
&excelize.GraphicOptions{ScaleX: 0.5, ScaleY: 0.5}); err != nil {
fmt.Println(err)
return
}
// ワークシートに画像を挿入し、画像の印刷プロパティを設定します
enable, disable := true, false
if err := f.AddPicture("Sheet1", "H2", "image.gif",
&excelize.GraphicOptions{
PrintObject: &enable,
LockAspectRatio: false,
OffsetX: 15,
OffsetY: 10,
Locked: &disable,
}); err != nil {
fmt.Println(err)
return
}
// ファイルを保存
if err = f.Save(); err != nil {
fmt.Println(err)
}
}