go中Excelize處理excel表實(shí)現(xiàn)帶數(shù)據(jù)校驗(yàn)的文件導(dǎo)出
1 Excelize介紹
Excelize 是 Go 語(yǔ)言編寫(xiě)的用于操作 Office Excel 文檔基礎(chǔ)庫(kù)。官方文檔:https://xuri.me/excelize/zh-hans/
引入方法
go get "github.com/xuri/excelize/v2"
2 相關(guān)需求與實(shí)現(xiàn)
2.1 數(shù)據(jù)的excel文件導(dǎo)出
需求:入?yún)⑹且粋€(gè)map,其鍵是每個(gè)sheet頁(yè)的名字,其值是一個(gè)二維切片。在每個(gè)sheet頁(yè)中依次寫(xiě)入切片中的數(shù)據(jù)。返回文件名和錯(cuò)誤信息。
代碼:
// 寫(xiě)入數(shù)據(jù)到export/*.xlsx
// datas: map[sheet]每個(gè)sheet頁(yè)的數(shù)據(jù)
// return: 文件名, error
func WriteExcel(datas map[string][][]string) (string, error) {
file := excelize.NewFile()
for sheetName, data := range datas {
index, _ := file.NewSheet(sheetName)
for i, row := range data {
for j, val := range row {
// 列行數(shù)字索引轉(zhuǎn)excel坐標(biāo)索引
cellName, _ := excelize.CoordinatesToCellName(j+1, i+1)
//fmt.Println("cellName:", cellName)
// 設(shè)置,寫(xiě)入
file.SetCellValue(sheetName, cellName, val)
}
}
// 創(chuàng)建表格
file.SetActiveSheet(index)
}
filename := "aaa" + ".xlsx"
_, err := os.ReadDir("aaa/")
if err != nil {
// 不存在就創(chuàng)建
err = os.MkdirAll("aaa/", fs.ModePerm)
if err != nil {
fmt.Println(err)
}
}
// 刪除默認(rèn)工作表
file.DeleteSheet("Sheet1")
err = file.SaveAs("aaa/" + filename)
if err != nil {
return "", err
}
return filename, nil
}
func main() {
datas := make(map[string][][]string)
datas["xxx"] = [][]string{{"A1", "B1", "C1", "d1", "E1", "G1", "H1", "I1"}, {"A2", "B2", "C2"}, {"A3", "B3", "C3"}}
datas["yyy"] = [][]string{{"X1", "Y1", "Z1"}, {"X2", "Y2", "Z2"}, {"X3", "Y3", "Z3"}}
fileName, err := WriteExcel(datas)
if err != nil {
fmt.Println("Write excel error: ", err)
return
}
fmt.Println("Write excel success, file name is: ", fileName)輸出文件:


2.2 帶數(shù)據(jù)校驗(yàn)的excel文件導(dǎo)出
需求:入?yún)⑹且粋€(gè)map,其鍵是每個(gè)sheet頁(yè)的名字,其值是一個(gè)二維切片。在每個(gè)sheet頁(yè)中依次寫(xiě)入切片中的數(shù)據(jù)。返回文件名和錯(cuò)誤信息。數(shù)據(jù)校驗(yàn):A列只能輸入a,aa,aaa,aaaa;B列只能輸入b,bb;C列只能輸入c,cc,ccc。
代碼:
func WriteExcelValidation(datas map[string][][]string, validations map[string][]string) (string, error) {
file := excelize.NewFile()
for sheetName, data := range datas {
// 創(chuàng)建sheet
index, _ := file.NewSheet(sheetName)
// 有效性校驗(yàn)
for col, validation := range validations {
dv := excelize.NewDataValidation(true)
dv.SetSqref(col + "2:" + col + "1048576")
err := dv.SetDropList(validation)
if err != nil {
return "", err
}
file.AddDataValidation(sheetName, dv)
}
for i, row := range data {
for j, val := range row {
// 列行數(shù)字索引轉(zhuǎn)excel坐標(biāo)索引
cellName, _ := excelize.CoordinatesToCellName(j+1, i+1)
// 設(shè)置,寫(xiě)入
file.SetCellValue(sheetName, cellName, val)
}
}
// 創(chuàng)建表格
file.SetActiveSheet(index)
}
filename := "bbb" + ".xlsx"
// 創(chuàng)建目錄
_, err := os.ReadDir("aaa/")
if err != nil {
// 不存在就創(chuàng)建
err = os.MkdirAll("aaa/", fs.ModePerm)
if err != nil {
return "", err
}
}
file.DeleteSheet("Sheet1")
err = file.SaveAs("aaa/" + filename)
if err != nil {
return "", err
}
return filename, nil
}
func main() {
validations := make(map[string][]string)
validations["A"] = []string{"a", "aa", "aaa", "aaaa"}
validations["B"] = []string{"b", "bb"}
validations["E"] = []string{"c", "cc", "ccc"}
datas := make(map[string][][]string)
datas["xxx"] = [][]string{{"A1", "B1", "C1", "d1", "E1", "G1", "H1", "I1"}, {"A2", "B2", "C2"}, {"A3", "B3", "C3"}}
datas["yyy"] = [][]string{{"X1", "Y1", "Z1"}, {"X2", "Y2", "Z2"}, {"X3", "Y3", "Z3"}}
fileName, err := WriteExcelValidation(datas, validations)
if err != nil {
fmt.Println("Write excel error: ", err)
return
}
fmt.Println("Write excel success, file name is: ", fileName)
}輸出文件:

到此這篇關(guān)于go中Excelize處理excel表實(shí)現(xiàn)帶數(shù)據(jù)校驗(yàn)的文件導(dǎo)出的文章就介紹到這了,更多相關(guān)go Excelize excel導(dǎo)出內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
GO Cobra Termui庫(kù)開(kāi)發(fā)終端命令行小工具輕松上手
這篇文章主要為大家介紹了GO語(yǔ)言開(kāi)發(fā)終端命令行小工具,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01
go?sync?Waitgroup數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)基本操作詳解
這篇文章主要為大家介紹了go?sync?Waitgroup數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)基本操作詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01
golang 實(shí)現(xiàn)每隔幾分鐘執(zhí)行一個(gè)函數(shù)
這篇文章主要介紹了golang 實(shí)現(xiàn)每隔幾分鐘執(zhí)行一個(gè)函數(shù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12
詳解golang中bufio包的實(shí)現(xiàn)原理
這篇文章主要介紹了詳解golang中bufio包的實(shí)現(xiàn)原理,通過(guò)分析golang中bufio包的源碼,來(lái)了解為什么bufio能夠提高文件讀寫(xiě)的效率和速度2018-01-01
golang DNS服務(wù)器的簡(jiǎn)單實(shí)現(xiàn)操作
這篇文章主要介紹了golang DNS服務(wù)器的簡(jiǎn)單實(shí)現(xiàn)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-04-04
Golang切片連接成字符串的實(shí)現(xiàn)示例
本文主要介紹了Golang切片連接成字符串的實(shí)現(xiàn)示例,可以使用Go語(yǔ)言中的內(nèi)置函數(shù)"String()"可以將字節(jié)切片轉(zhuǎn)換為字符串,具有一定的參考價(jià)值,感興趣的可以了解一下2023-11-11

