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

github.com/360EntSecGroup-Skylar/excelize

github.com/tealeg/xlsx

可以使用以上两个库

代码如下:

复制代码
// DownLoadTemplate 创建并下载一个 Excel 模板
func (c *TemplateController) DownLoadTemplate() {
	var file *xlsx.File
	var sheet *xlsx.Sheet
	var row *xlsx.Row
	var 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模板

导入功能请看下一篇文章

相关推荐
独自破碎E7 分钟前
【前序+中序】重建二叉树
java·开发语言
萧曵 丶11 分钟前
Spring 全套高频面试题(由浅到深 完整版)
java·后端·spring
武子康12 分钟前
大数据-213 Python 手写 K-Means 聚类实战(鸢尾花 Iris 数据集):从距离函数到迭代收敛与坑点
大数据·后端·机器学习
神奇小汤圆14 分钟前
MySQL大事务的Recovery优化
后端
2301_7657151419 分钟前
C语言轮子制造
c语言·开发语言·制造
魔术师卡颂21 分钟前
提问量暴跌 80% ,Stack Overflow 却赚翻了?
前端·后端·ai编程
量子炒饭大师22 分钟前
【C++入门】Cyber骇客的同名异梦——【C++重载函数】(与C的函数差异)
c语言·开发语言·c++·函数重载
charlie11451419125 分钟前
现代嵌入式C++教程:if constexpr——把编译期分支写得像写注释 —— 工程味实战指南
开发语言·c++·笔记·学习·嵌入式·现代c++
冰暮流星27 分钟前
javascript如何转换为字符串与布尔型
java·开发语言·javascript
LIZhang201628 分钟前
c++ 转化句柄,解决多线程安全释放问题
开发语言·c++