欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 健康 > 养生 > 使用go实现下载导入Excel模板

使用go实现下载导入Excel模板

2025/4/1 8:12:04 来源:https://blog.csdn.net/weixin_45582252/article/details/146501885  浏览:    关键词:使用go实现下载导入Excel模板

github.com/360EntSecGroup-Skylar/excelize

github.com/tealeg/xlsx

可以使用以上两个库

代码如下:

// DownLoadTemplate 创建并下载一个 Excel 模板
func (c *TemplateController) DownLoadTemplate() {var file *xlsx.Filevar sheet *xlsx.Sheetvar row *xlsx.Rowvar cell *xlsx.Cell// 创建新的 Excel 文件file = xlsx.NewFile()sheet, _ = file.AddSheet("Template")// 设置表格头headers := []string{"编号", "样件码", "创建人", "产品型号", "备注"}row = sheet.AddRow()for _, header := range headers {cell = row.AddCell()cell.Value = header}// 保存路径if !FileExists("static/tmp") {os.MkdirAll("static/tmp", os.ModePerm)}filename := "static/tmp/template_" + fmt.Sprintf("%d", time.Now().Unix()) + ".xlsx"err := file.Save(filename)if err != nil {fmt.Println(err)c.jsonResult(JRCodeFailed, "文件保存失败!", 0)return}defer os.Remove(filename) // 确保在下载后删除文件// 设置下载文件的名称now := time.Now()nowStr := fmt.Sprintf("%d%d%d%d%d%d", now.Year(), now.Month(), now.Day(), now.Hour(), now.Minute(), now.Second())servername := "template_" + nowStr + ".xlsx"// 发送文件到浏览器下载c.Ctx.Output.Download(filename, servername)
}// FileExists 检查文件或目录是否存在
func FileExists(filename string) bool {_, err := os.Stat(filename)return !os.IsNotExist(err)
}

在示例中,可以从浏览器下载一个由你自由定义的excel模板

导入功能请看下一篇文章

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词