golang对.xlsx文件的写入和读取,利用第三包github.com/tealeg/xlsx

luominggao123 · · 3935 次点击 · 开始浏览    置顶
这是一个创建于 的主题,其中的信息可能已经有所发展或是发生改变。

``` package main import ( "fmt" "github.com/tealeg/xlsx" ) type Member struct { Name string `xlsx:"0"` Age int `xlsx:"1"` } func main() { WriteToXlsx() ReadXlsx() } //把Member结构的数据写入到.xlsx文件当中 func WriteToXlsx() { var file *xlsx.File var sheet *xlsx.Sheet var row *xlsx.Row var err error file = xlsx.NewFile() sheet, err = file.AddSheet("Sheet1") if err != nil { fmt.Printf(err.Error()) } row = sheet.AddRow() member := &Member{"A1", 21} a := row.WriteStruct(member, -1) fmt.Println(a) file.Save("MyXLSXFile.xlsx") } //把.xlsx文件的内容读取到Member结构体中. func ReadXlsx() { xlFile, err := xlsx.OpenFile("MyXLSXFile.xlsx") if err != nil { fmt.Println("err:", err) } members := make([]Member, 0) member := new(Member) length := xlFile.Sheet["Sheet1"].MaxRow for i := 0; i < length; i++ { xlFile.Sheet["Sheet1"].Rows[i].ReadStruct(member) if err != nil { fmt.Println("err:", err) break } members = append(members, *member) } fmt.Println("members:", members) } ```

有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

3935 次点击  
加入收藏 微博
1 回复  |  直到 2020-10-12 13:40:55
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传