go 数据导出Excel&前台接收后端返回文件流并在浏览器提供下载

简介: go 数据导出Excel&前台接收后端返回文件流并在浏览器提供下载

前言


我还有一个朋友, 最近要实现一个数据导出excel的功能, 来看一下主要怎么实现吧


20200519091617135.png

实现


主要用到了 https://godoc.org/github.com/tealeg/xlsx


测试脚本


package main
import (
  "testing"
)
import (
  "github.com/tealeg/xlsx"
)
func TestCreateExcel(t *testing.T) {
  var user = struct {
    Name string
    Age  int
  }{}
  user.Name, user.Age = "飞起来", 11
  // 生成一个新的文件
  file := xlsx.NewFile()
  // 添加sheet页
  sheet, _ := file.AddSheet("Sheet1")
  // 插入表头
  titleRow := sheet.AddRow()
  titleRow.AddCell().Value = "名字"
  titleRow.AddCell().Value = "年龄"
  // 插入内容
  for a := 0; a <= 2; a++ {
    row := sheet.AddRow()
    row.WriteStruct(&user, -1)
  }
  // 保存文件
  err := file.Save("file.xlsx")
  if err != nil {
    panic(err)
  }
}

这是生成的excel文件

20200514204944249.png

封装个公用方法


主要的功能还是api生成excel返回给前端提供用户下载(接口如果是get请求的话则可以直接下载)

// DataToExcel 数据导出excel, dataList里面的对象为指针
func DataToExcel(w http.ResponseWriter, r *http.Request, titleList []string, dataList []interface{}, fileName string) {
  // 生成一个新的文件
  file := xlsx.NewFile()
  // 添加sheet页
  sheet, _ := file.AddSheet("Sheet1")
  // 插入表头
  titleRow := sheet.AddRow()
  for _, v := range titleList {
    cell := titleRow.AddCell()
    cell.Value = v
    cell.GetStyle().Font.Color = "00FF0000"
  }
  // 插入内容
  for _, v := range dataList {
    row := sheet.AddRow()
    row.WriteStruct(v, -1)
  }
  fileName = fmt.Sprintf("%s.xlsx", fileName)
  //_ = file.Save(fileName)
  w.Header().Add("Content-Disposition", fmt.Sprintf(`attachment; filename="%s"`, fileName))
  w.Header().Add("Content-Type", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet")
  var buffer bytes.Buffer
  _ = file.Write(&buffer)
  content := bytes.NewReader(buffer.Bytes())
  http.ServeContent(w, r, fileName, time.Now(), content)
}

这样就可以了, 然后下面是让前端朋友写的测试代码, 主要使用blob来实现

fetch("http://127.0.0.1:9999/test", {
    method: "POST",
    body: JSON.stringify({
        "page": 1,
        "size": 10,
    }),
    headers: {
    },
    responseType: 'blob'
}).then(async (res) => {
    let blob = await res.blob();
    const link = document.createElement('a');
    blob = new Blob([blob], {type: 'application/x-excel'});
    console.log(blob);
    link.style.display = 'none';
    link.href = URL.createObjectURL(blob);
    link.download = "测试execl.xlsx";
    document.body.appendChild(link);
    link.click();
    document.body.removeChild(link);
}).catch(error => {
    console.log(error);
});


目录
相关文章
|
8天前
|
JSON 中间件 Go
go语言后端开发学习(四) —— 在go项目中使用Zap日志库
本文详细介绍了如何在Go项目中集成并配置Zap日志库。首先通过`go get -u go.uber.org/zap`命令安装Zap,接着展示了`Logger`与`Sugared Logger`两种日志记录器的基本用法。随后深入探讨了Zap的高级配置,包括如何将日志输出至文件、调整时间格式、记录调用者信息以及日志分割等。最后,文章演示了如何在gin框架中集成Zap,通过自定义中间件实现了日志记录和异常恢复功能。通过这些步骤,读者可以掌握Zap在实际项目中的应用与定制方法
go语言后端开发学习(四) —— 在go项目中使用Zap日志库
|
11天前
|
缓存 前端开发 中间件
[go 面试] 前端请求到后端API的中间件流程解析
[go 面试] 前端请求到后端API的中间件流程解析
|
3天前
|
JavaScript 前端开发
Vue中传递自定义参数到后端、后端获取数据(使用Map接收参数)
这篇文章讲述了如何在Vue中通过Axios二次封装传递自定义参数到后端,并展示了后端如何使用Map接收这些参数,以及如何避免参数转换错误和统一接口设计的方法。
|
5天前
|
算法 NoSQL 中间件
go语言后端开发学习(六) ——基于雪花算法生成用户ID
本文介绍了分布式ID生成中的Snowflake(雪花)算法。为解决用户ID安全性与唯一性问题,Snowflake算法生成的ID具备全局唯一性、递增性、高可用性和高性能性等特点。64位ID由符号位(固定为0)、41位时间戳、10位标识位(含数据中心与机器ID)及12位序列号组成。面对ID重复风险,可通过预分配、动态或统一分配标识位解决。Go语言实现示例展示了如何使用第三方包`sonyflake`生成ID,确保不同节点产生的ID始终唯一。
go语言后端开发学习(六) ——基于雪花算法生成用户ID
|
6天前
|
JSON 缓存 监控
go语言后端开发学习(五)——如何在项目中使用Viper来配置环境
Viper 是一个强大的 Go 语言配置管理库,适用于各类应用,包括 Twelve-Factor Apps。相比仅支持 `.ini` 格式的 `go-ini`,Viper 支持更多配置格式如 JSON、TOML、YAML
go语言后端开发学习(五)——如何在项目中使用Viper来配置环境
|
12天前
|
JSON 机器人 Go
go接收alertmanager告警并发送钉钉
go接收alertmanager告警并发送钉钉
|
1月前
|
前端开发 JavaScript Go
|
1月前
|
算法 网络协议 Linux
|
1月前
|
前端开发 JavaScript PHP
技术心得:前端点击按钮,导入excel文件,上传到后台,excel接收和更新数据
技术心得:前端点击按钮,导入excel文件,上传到后台,excel接收和更新数据
30 0
|
2月前
|
中间件 Go
go语言后端开发学习(三)——基于validator包实现接口校验
go语言后端开发学习(三)——基于validator包实现接口校验