golang 读取excel(xlsx文件) 时间格式解析

木申 · · 2980 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

问题起源

最近在写一个读取xlsx文件,并解析其中数据的项目,在所有的数据都就绪之后,却遇到了时间格式获取不正确的问题

时间格式

image.png

我查询到的结果

image.png

我的代码
func main() {
 f, err := excelize.OpenFile("./template.xlsx")
   if err != nil {
      log.Fatal(err)
   }
 rows := f.GetRows("Sheet1")
   for _, row := range rows {
        fmt.Println("row[1]: ", row[1])
   }
}

第一次尝试问题解决

通过查找官方issue,我得到了另一个结果,可以使用number_format方法,转化格式
image.png
由此,我得到了另一个结果,43831
image.png

func main() {
 f, err := excelize.OpenFile("/Users/zheng/Desktop/template.xlsx")
   if err != nil {
        log.Fatal(err)
   }
 style, err := f.NewStyle(`{"number_format": 0}`)
   if err != nil {
        fmt.Println(err)
   }
 f.SetCellStyle("Sheet1", "B2", "B2", style)
   rows := f.GetRows("Sheet1")
   for _, row := range rows {
        fmt.Println("row[1]: ", row[1])
   }
}

第二次尝试解决问题

我发现,这个数字43831,是距离1990-00-01的天数,这就是所谓的excel时间,从而我得到了我想要的答案
image.png

func excelDateToDate(excelDate string) time.Time {
    excelTime := time.Date(1899, time.December, 30, 0, 0, 0, 0, time.UTC)
    var days, _ = strconv.Atoi(excelDate)
   return excelTime.Add(time.Second * time.Duration(days*86400))
}
func main() {
    f, err := excelize.OpenFile("/Users/zheng/Desktop/template.xlsx")
   if err != nil {
    log.Fatal(err)
   }
    style, err := f.NewStyle(`{"number_format": 0}`)
   if err != nil {
    fmt.Println(err)
   }
    f.SetCellStyle("Sheet1", "B2", "B2", style)
   rows := f.GetRows("Sheet1")
   for _, row := range rows {
    fmt.Println("row[1]: ", row[1])
   }
    fmt.Println(excelDateToDate("43831"))
}

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

本文来自:Segmentfault

感谢作者:木申

查看原文:golang 读取excel(xlsx文件) 时间格式解析

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

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