一文帶你搞懂Go如何讀寫Excel文件
Excelize是一個用純Go語言編寫的庫,提供瞭一組函數,可以對XLAM / XLSM / XLSX / XLTM / XLTX文件進行讀寫。支持讀寫由Microsoft Excel™2007及以後版本生成的電子表格文檔。通過高兼容性支持復雜組件,並提供流API從具有大量數據的工作表中生成或讀取數據。該庫需要Go 1.16或更高版本。
那麼本篇文章將會介紹我們操作Excel的常用功能,如下:
- 生成一個新的Excel文件
- 向Excel文件中追加內容
- 解析Excel文件內容
- 使用Http協議上傳並解析Excel文件
- 使用Http協議將數據轉換為Excel文件並下載
1.下載依賴庫
go get github.com/xuri/excelize # Go Modules使用這個命令 go get github.com/xuri/excelize/v2
2.具體操作
2.1 生成一個新的Excel文件
func WriteNewExcel() { f := excelize.NewFile() // 創建一個sheet index := f.NewSheet("Sheet2") // 根據sheet和坐標 確定一個值 // 例如f.SetCellValue("Sheet2", "A2", "Hello world.")就是在Sheet表中A列第2行的格子裡填入Hello world. f.SetCellValue("Sheet2", "A2", "Hello world.") f.SetCellValue("Sheet1", "B1", 100) f.SetCellValue("Sheet1", "B2", 100) // 將新的sheet添加到Excel中 f.SetActiveSheet(index) // 保存Excel if err := f.SaveAs("Book1.xlsx"); err != nil { fmt.Println(err) } }
2.2 向Excel文件中追加內容
func WriteExcel() { f, _ := excelize.OpenFile("Book1.xlsx") index := f.NewSheet("Sheet2") f.SetCellValue("Sheet2", "A2", "Hello world.") f.SetCellValue("Sheet1", "B1", 100) f.SetCellValue("Sheet1", "B2", 100) f.SetActiveSheet(index) if err := f.SaveAs("Book1.xlsx"); err != nil { fmt.Println(err) } }
2.3 解析Excel文件內容
func ReadExcel() { f, err := excelize.OpenFile("Book1.xlsx") if err != nil { fmt.Println(err) return } defer func() { if err := f.Close(); err != nil { fmt.Println(err) } }() // 根據sheet和坐標讀取某一個格子的值 cell, err := f.GetCellValue("Sheet1", "B2") if err != nil { fmt.Println(err) return } fmt.Println(cell) // 按行讀取全部 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() } }
2.4 使用Http協議上傳並解析Excel文件
func HttpReadExcel() { f := func(read io.Reader) { file, err := excelize.OpenReader(read) if err != nil { fmt.Println(err) return } for _, item := range file.GetSheetList() { rows, _ := file.GetRows(item) // rows是一個二維數組 for i := range rows { strs := rows[i] for j := range strs { str := rows[i][j] fmt.Println(str) } } } } http.HandleFunc("/excel", func(w http.ResponseWriter, r *http.Request) { file, _, err := r.FormFile("file") if err != nil { fmt.Println(err) return } fileBytes, err := ioutil.ReadAll(file) if err != nil { fmt.Println(err) return } reader := bytes.NewReader(fileBytes) f(reader) w.Write([]byte("Hello Http Get!")) }) http.ListenAndServe(":8080", nil) }
2.5 使用Http協議將數據轉換為Excel文件並下載
func HttpDownloadExcel() { fun := func(fileName string) *bytes.Reader { f := excelize.NewFile() f.SetCellValue("Sheet1", "B1", 100) err := f.SaveAs(fileName) if err != nil { fmt.Println(err) } var buffer bytes.Buffer _ = f.Write(&buffer) return bytes.NewReader(buffer.Bytes()) } http.HandleFunc("/downloadExcel", func(w http.ResponseWriter, r *http.Request) { reader := fun("Book2.xlsx") // 重新設置文件名稱 w.Header().Set("Content-Disposition", "attachment; filename="+"Book2.xlsx") io.Copy(w, reader) }) http.ListenAndServe(":8080", nil) }
3.小總結
以上功能隻需靈活擴展後基本上就可以覆蓋大部分業務瞭,但是有一點需要註意,在2.5使用Http協議將數據轉換為Excel文件並下載這個操作中,需要將文件進行重命名,這個名稱可以自定義,也可以由服務端指定,但是需要以相關文件類型的名稱做後綴,否則會輸出zip壓縮文件,很難看懂。
到此這篇關於一文帶你搞懂Go如何讀寫Excel文件的文章就介紹到這瞭,更多相關Go讀寫Excel文件內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Go語言操作Excel利器之excelize類庫詳解
- Golang 模塊引入及表格讀寫業務快速實現示例
- Golang生成Excel文檔的方法步驟
- Go Excelize API源碼閱讀SetSheetViewOptions示例解析
- Go Excelize API源碼閱讀GetPageLayout及SetPageMargins