網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
介紹
在很多管理系統(tǒng)下都有不少讓后端進(jìn)行表格進(jìn)行操作的業(yè)務(wù)需求,本期就帶大家了解一下Golang中如何使用模塊引入的,以及講解怎么快速的使用excelize庫(kù),對(duì)表格進(jìn)行讀寫創(chuàng)建的。
正文
配置模塊引入環(huán)境
我們?cè)谄谕趘scode終端中也可以使用模塊引入,它是 Go 1.11后新版模塊管理方式。
go env -w GO111MODULE=auto
其 GO111MODULE
可以傳遞:
- auto:在其外層且根目錄里有
go.mod
文件時(shí),則開啟模塊支持,否者無模塊支持。 - on:開啟模塊支持。
- off:無模塊支持。
然后,初始化這個(gè)項(xiàng)目,就會(huì)生成一個(gè) go.mod
文件。
go mod init excel-demo
go.mod
是Go 1.11版本引入的官方的包管理工具(之前為 gopath
來管理),它可以理解為前端開發(fā)中的 npm
的作用,主要是為了解決沒有記錄依賴包具體版本查閱困難的問題,也極大程度上方便了依賴包的管理。
引入excelize庫(kù)
excelize 是一個(gè)用于讀寫 Microsoft Excel?2007 及更高版本生成的電子表格文檔(XLAM / XLSM / XLSX / XLTM / XLTX)的 Go 語(yǔ)言庫(kù),而且更新維護(hù)頻繁且非常好用。
引入excelize
go get github.com/xuri/excelize/v2
這里因?yàn)檎军c(diǎn)是國(guó)外的所以經(jīng)常會(huì)因無法訪問而超時(shí)。此時(shí),不要慌,我們換一個(gè)國(guó)內(nèi)的代理就好了。
go env -w GOPROXY=https://goproxy.cn
創(chuàng)建表格
package main import ( "fmt" "github.com/xuri/excelize/v2" ) func createExcel(){ // 創(chuàng)建表格文件 f := excelize.NewFile() // 在Sheet1設(shè)置A1項(xiàng)的值 f.SetCellValue("Sheet1", "A1", "這是Sheet1的A1項(xiàng)") // 創(chuàng)建新的Sheet,命名為Sheet2 selectIndex := f.NewSheet("Sheet2") // 在Sheet2設(shè)置B2項(xiàng)的值 f.SetCellValue("Sheet2", "B2", "這是Sheet2的B2項(xiàng)") // 切換到Sheet2 f.SetActiveSheet(selectIndex) // 保存文件 if err := f.SaveAs("test.xlsx"); err != nil { fmt.Println(err) } } func main() { // 執(zhí)行創(chuàng)建表格 createExcel() }
按照以上是創(chuàng)建文件并在列上隨便寫入一些數(shù)據(jù)然后保存下來,非常的簡(jiǎn)單,現(xiàn)在我們來執(zhí)行一下,就會(huì)發(fā)現(xiàn)當(dāng)前目錄會(huì)多出一個(gè)text.xlsx文件,沒錯(cuò),這就是我們剛才生成出來的表格文件,打開它就可以看到我們剛才寫入的一些內(nèi)容了。
讀取表格
func openExcel(){ // 讀取test.xlsx表格文件 f, err := excelize.OpenFile("test.xlsx") if err != nil { fmt.Println(err) return } // 獲取Sheet2的B2項(xiàng)的值 cell, err := f.GetCellValue("Sheet2", "B2") if err != nil { fmt.Println(err) return } fmt.Println(cell) fmt.Println("---------------") // 獲取Sheet1所有的項(xiàng) rows, err := f.GetRows("Sheet1") if err != nil { fmt.Println(err) return } // 遍歷Sheet1所有的項(xiàng)并打印出來 for _, row := range rows { for _, colCell := range row { fmt.Print(colCell, "\t") } fmt.Println() } }
上面做的操作是把我們剛才保存好的表格文件的內(nèi)容讀取出來,這里分了兩種形式,一種是用 GetCellValue
方法讀取某個(gè)sheet的某一項(xiàng),另一種是用 GetRows
對(duì)獲取整個(gè)sheet的項(xiàng),然后for循環(huán)遍歷出來。
寫入表格
剛剛在創(chuàng)建的時(shí)候其實(shí)已經(jīng)使用 SetCellValue
方法對(duì)表格的寫入操作,但這還遠(yuǎn)遠(yuǎn)不夠,因?yàn)檫€有很多東西我們可以寫入進(jìn)去,比如說圖表和圖片甚至是其他表格文件。圖表這里先簡(jiǎn)單說明一下,它用了 AddChart
方法也是對(duì)某一項(xiàng)進(jìn)行操作,插入相關(guān)數(shù)據(jù)進(jìn)去,形式如下(詳見文檔):
if err := f.AddChart("Sheet1", "E1", `{ "type": "col3DClustered", "series": [ { "name": "Sheet1!$A$2", "categories": "Sheet1!$B$1:$D$1", "values": "Sheet1!$B$2:$D$2" }] }`); err != nil { fmt.Println(err) return }
接下來,我們主要講一下圖片是如何寫入進(jìn)表格的,首先,我們先準(zhǔn)備一張圖片,就放在assets目錄吧,然后在到 import
中導(dǎo)入jpeg和png,目的是明確后面要解析的圖片(目前可以解析出jpeg,jpg,png格式的圖片了),如果不寫或者格式不對(duì)則會(huì)出現(xiàn) image: unknown format
的提示。
package main import ( "fmt" _ "image/jpeg" _ "image/png" "github.com/xuri/excelize/v2" )
然后我們還是要讀取一下剛剛生成出來的test.xlsx表格文件,再把圖片寫入進(jìn)去。
func setPic(){ f, err := excelize.OpenFile("test.xlsx") if err != nil { fmt.Println(err) return } // 導(dǎo)入并設(shè)置圖片 if err := f.AddPicture("Sheet2", "C3", "assets/anya.png", `{ "x_offset": 10, "y_offset": 10, "x_scale": 0.8, "y_scale": 0.8 }`); err != nil { fmt.Println(err) } // 保存剛才的操作 if err = f.Save(); err != nil { fmt.Println(err) } }
而且圖片還可以這是位置,大小等參數(shù),但這里一定要記住不管添加了什么最后一定要保存一下,不然就是一場(chǎng)空。最后么,一個(gè)小阿尼亞就寫入到了表格中啦~
結(jié)語(yǔ)
原文鏈接:https://juejin.cn/post/7123120168167243790
相關(guān)推薦
- 2022-08-21 Go語(yǔ)言的互斥鎖的詳細(xì)使用_Golang
- 2023-02-02 C++示例講解觀察者設(shè)計(jì)模式_C 語(yǔ)言
- 2022-08-14 Python全局變量關(guān)鍵字global的簡(jiǎn)單使用_python
- 2022-04-25 Entity?Framework?Core批處理SQL語(yǔ)句_實(shí)用技巧
- 2022-08-05 RedisConfig 配置文件
- 2022-08-21 利用Python制作本地Excel的查詢與生成的程序問題_python
- 2022-04-08 從頭學(xué)習(xí)C語(yǔ)言之字符串處理函數(shù)_C 語(yǔ)言
- 2022-10-12 Android自定義View實(shí)現(xiàn)遙控器按鈕_Android
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支