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);
});


目录
相关文章
|
3月前
|
XML 缓存 JSON
为什么浏览器中有些图片、PDF等文件点击后有些是预览,有些是下载
为什么浏览器中有些图片、PDF等文件点击后有些是预览,有些是下载
251 0
|
3月前
|
缓存 前端开发 中间件
[go 面试] 前端请求到后端API的中间件流程解析
[go 面试] 前端请求到后端API的中间件流程解析
|
22天前
|
Web App开发 Java
使用java操作浏览器的工具selenium-java和webdriver下载地址
【10月更文挑战第12天】Selenium-java依赖包用于自动化Web测试,版本为3.141.59。ChromeDriver和EdgeDriver分别用于控制Chrome和Edge浏览器,需确保版本与浏览器匹配。示例代码展示了如何使用Selenium-java模拟登录CSDN,包括设置驱动路径、添加Cookies和获取页面源码。
|
2月前
|
JSON 前端开发 JavaScript
java中post请求调用下载文件接口浏览器未弹窗而是返回一堆json,为啥
客户端调接口需要返回另存为弹窗,下载文件,但是遇到的问题是接口调用成功且不报错,浏览器F12查看居然返回一堆json,而没有另存为弹窗; > 正确的效果应该是:接口调用成功且浏览器F12不返回任何json,而是弹窗另存为窗口,直接保存文件即可。
141 2
|
1月前
|
前端开发 JavaScript Java
导出excel的两个方式:前端vue+XLSX 导出excel,vue+后端POI 导出excel,并进行分析、比较
这篇文章介绍了使用前端Vue框架结合XLSX库和后端结合Apache POI库导出Excel文件的两种方法,并对比分析了它们的优缺点。
226 0
|
3月前
|
JSON 中间件 Go
go语言后端开发学习(四) —— 在go项目中使用Zap日志库
本文详细介绍了如何在Go项目中集成并配置Zap日志库。首先通过`go get -u go.uber.org/zap`命令安装Zap,接着展示了`Logger`与`Sugared Logger`两种日志记录器的基本用法。随后深入探讨了Zap的高级配置,包括如何将日志输出至文件、调整时间格式、记录调用者信息以及日志分割等。最后,文章演示了如何在gin框架中集成Zap,通过自定义中间件实现了日志记录和异常恢复功能。通过这些步骤,读者可以掌握Zap在实际项目中的应用与定制方法
130 1
go语言后端开发学习(四) —— 在go项目中使用Zap日志库
|
3月前
|
算法 NoSQL 中间件
go语言后端开发学习(六) ——基于雪花算法生成用户ID
本文介绍了分布式ID生成中的Snowflake(雪花)算法。为解决用户ID安全性与唯一性问题,Snowflake算法生成的ID具备全局唯一性、递增性、高可用性和高性能性等特点。64位ID由符号位(固定为0)、41位时间戳、10位标识位(含数据中心与机器ID)及12位序列号组成。面对ID重复风险,可通过预分配、动态或统一分配标识位解决。Go语言实现示例展示了如何使用第三方包`sonyflake`生成ID,确保不同节点产生的ID始终唯一。
go语言后端开发学习(六) ——基于雪花算法生成用户ID
|
3月前
|
JSON 缓存 监控
go语言后端开发学习(五)——如何在项目中使用Viper来配置环境
Viper 是一个强大的 Go 语言配置管理库,适用于各类应用,包括 Twelve-Factor Apps。相比仅支持 `.ini` 格式的 `go-ini`,Viper 支持更多配置格式如 JSON、TOML、YAML
go语言后端开发学习(五)——如何在项目中使用Viper来配置环境
|
4月前
|
前端开发 JavaScript Go
|
5月前
|
中间件 Go
go语言后端开发学习(三)——基于validator包实现接口校验
go语言后端开发学习(三)——基于validator包实现接口校验