Golang 엑셀 파일을 쓰고 읽는 XLSX 라이브러리 알아보기
오늘은 Golang으로 마이크로소프트의 엑셀 파일을 쓰고 읽을 수 있는 XLSX 라이브러리를 알아보려 합니다.
XLSX 설치
우선 Golang의 환경을 구성하기 위해 https://golang.org/dl/ 에서 윈도우, 리눅스, 맥에서 설치 프로그램을 내려받을 수 있습니다.
맥에서 brew로 쉽게 설치할 수 있습니다.
brew install go
우분투에서도 apt로 쉽게 설치할 수 있습니다.
sudo apt-get install golang-go
맥에서 Golang의 버전을 올리려면 brew를 이용합니다.
brew upgrade go
우분투에서도 Golang의 버전을 올리려면 backports 저장소를 등록하고 apt를 이용합니다.
sudo add-apt-repository ppa:longsleep/golang-backports
sudo apt-get update
sudo apt-get install golang-go
go get으로 XLSX 패키지를 설치합니다.
go get github.com/tealeg/xlsx
홈의 go 폴더에 XLSX 소스코드와 패키지 파일이 생성됩니다.
예제
package main
해당 소스코드를 실행 파일로 인식하게 해주도록 main이라고 선언합니다.
import (
"fmt"
"github.com/tealeg/xlsx"
)
fmt와 xlsx를 가져옵니다.
func main() {
file := xlsx.NewFile()
파일을 생성합니다.
sheet, err := file.AddSheet("Sheet1")
if err != nil {
panic(err)
}
생성한 파일 객체에서 시트를 생성합니다.
row := sheet.AddRow()
cell := row.AddCell()
cell.Value = "VALUE"
Row를 생성하고, cell에 문자열을 기록합니다.
err = file.Save("test.xlsx")
if err != nil {
panic(err)
}
위 파일 객체로 test라는 이름의 xlsx 엑셀 파일을 저장합니다.
file, err = xlsx.OpenFile("test.xlsx")
if err != nil {
panic(err)
}
저장한 test.xlsx 파일을 엽니다.
for _, sheet := range file.Sheets {
for _, row := range sheet.Rows {
for _, cell := range row.Cells {
fmt.Println(cell.String())
}
}
}
}
test.xlsx의 sheet를 반복문으로 꺼내오고, row의 cell 값들을 전부 순차적으로 가져옵니다.
Written on September 27, 2019