当前位置: 首页 > article >正文

Go语言后台实现选中式导出excel文件

实现选中导出为excel文件的基本实现方案是前端将选中的数据传递给后端,后台接受这些数据生成excel文件的流,将流返回给前端并在响应体设置文件的格式。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
这时只要将需要下载的数据提交到改接口就会返回文件流数据,提供下载。具体实现代码如下:

  • 工具库

https://github.com/douyacun/go-struct-excel

go get github.com/douyacun/go-struct-excel

具体的代码实现参考github示例代码

  • 创建导出的结构体
type Company struct {
    ID                    string    `json:"id" excel:"主键"`
    Creater               string    `json:"creater" excel:"创建人"`
    CreateTime            string    `json:"create_time" excel:"创建时间"`
    Updater               string    `json:"updater" excel:"更新人"`
    UpdateTime            string    `json:"update_time" excel:"更新时间"`
    IsDelete              int32     `json:"is_delete" excel:"是否删除"`
    Version               int32     `json:"version" excel:"版本"`
    TenantID              string    `json:"tenant_id" excel:"多版本唯一标识"`
    CreditCode            string    `json:"credit_code" excel:"企业社会信用代码"`
    Name                  string    `json:"name" excel:"企业名称"`
    Address               string    `json:"address" excel:"企业地址"`
    Type                  string    `json:"type" excel:"企业类型"`
    LegalPersonName       string    `json:"legal_person_name" excel:"企业法人"`
    LegalPersonIDNo       string    `json:"legal_person_id_no" excel:"企业法人身份证"`
    LegalPersonPhoneNo    string    `json:"legal_person_phone_no" excel:"企业法人电话"`
    ContractPersonName    string    `json:"contract_person_name" excel:"企业联系人姓名"`
    ContractPersonIDNo    string    `json:"contract_person_id_no" excel:"企业联系人身份证"`
    ContractPersonPhoneNo string    `json:"contract_person_phone_no" excel:"企业联系人联系电话"`
    RegisterDate          string    `json:"register_date" excel:"注册时间"`
    Remark                string    `json:"remark" excel:"备注"`
    Lon                   float64   `json:"lon" excel:"经度"`
    Lat                   float64   `json:"lat" excel:"纬度"`
    Geom                  string    `json:"geom" excel:"位置信息"`
    ProvinceID            string    `json:"province_id" excel:"省级编码"`
    CityID                string    `json:"city_id" excel:"市级编码"`
    AreaID                string    `json:"area_id" excel:"区级编码"`
}

json标签的作用用于结构体来自前端的数据,excel的标签用户生成excel的表头。

  • 生成excel的文件流
// 导出为excel文件流
// T为任意了类型
// data参数为T类型的指针数组,必须是指针数组
// name为导出的问加盟
func Export[T any](data []T, name string, sheetName string) ([]byte, error) {
	// helloworld.xlsx
	if name == "" {
		name = "test.xlsx"
	}
	if !strings.Contains(name, ".xlsx") {
		name = name + ".xlsx"
	}
	excel := ex.NewExcel(name)
	defer excel.File.Close()
	sheet, err := excel.AddSheet(sheetName)
	if err != nil {
		return nil, err
	}
	if err = sheet.AddData(data); err != nil {
		return nil, err
	}
	return excel.Bytes()
}

这里包装了一下,数据使用指针数组传递,同时传递exel文件名和sheet页数

  • 接口返回文件流
// 导出企业库
func ExportCom(c *fiber.Ctx) error {
	var req []model.BaseCompanyCopy

	if err := c.BodyParser(&req); err != nil {
		return http_resp.Fail(c, "参数错误")
	}
	var data []*excel.Company
	for i := 0; i < len(req); i++ {
		tmp := utils.StructTimeCopy[model.BaseCompanyCopy, excel.Company](req[i])
		data = append(data, &tmp)
	}
	export, err := excel.Export[*excel.Company](data, "企业信息", "企业信息")
	if err != nil {
		return http_resp.Fail(c, "导出失败")
	}
	c.Set("Content-Disposition", "attachment; filename=file"+".xlsx")
	return c.Send(export)
}

这里使用fiber的web框架ctx.Set()这部很重要,用户设置文件的下载文件的名称。


http://www.kler.cn/a/442791.html

相关文章:

  • Three.js 用户交互:构建沉浸式3D体验的关键
  • [笔记] 使用 Jenkins 实现 CI/CD :从 GitLab 拉取 Java 项目并部署至 Windows Server
  • C++ union 联合(八股总结)
  • 一学就废|Python基础碎片,OS模块
  • 鼠标过滤驱动
  • Leetcode刷题笔记—栈与队列
  • 鸿蒙NEXT开发案例:颜文字搜索器
  • [bug] StarRocks borker load意向之外的bug
  • 《C 语言携手 PaddlePaddle C++ API:开启深度学习开发新征程》
  • SEO初学者-搜索引擎如何工作
  • 练习题:一维数组
  • pytest入门三:setup、teardown
  • 【WRF教程第3.3期】预处理系统 WPS 详解:以4.5版本为例
  • 第十四届蓝桥杯Scratch国赛真题—转动的车轮
  • Android 上集成 TikTok SDK及数据归因
  • c#基于tcp的打印机共享程序可以打印图片
  • redis集群 服务器更换ip,怎么办,怎么更换redis集群的ip
  • HttpSevletRequest Body信息不能被多次读取的问题
  • Java-注解
  • ARM/Linux嵌入式面经(五七):东方微电
  • AIGC魔性视频创作教程,即梦AI、海螺AI、混元大模型、通义万相
  • 低代码/无代码开发平台下的API接口创新实践
  • 请求三方http工具
  • ElasticSearch08-分析器详解
  • SQL 自然连接(Natural Join)详解
  • 物理信息神经网络(PINN)八课时教案