Golang 创建 Excel 文件

经常会遇到需要导出数据报表的需求,除了可以通过 encoding/csv 导出 CSV 以外,还可以使用
https://github.com/qax-os/excelize 导出 xlsx 等格式的 excel,下面封装了一个方法,支持多 sheet 的 excel 数据生成,导出按需在接口实现层添加 f.SaveAs("xxx.xlsx") 即可

go 复制代码
package excel

import (
	"fmt"

	"github.com/xuri/excelize/v2"
)

type SheetData struct {
	SheetName string
	Headers   []string
	Rows      [][]interface{}
}

// GenerateExcelBySheets 生成 excel 表格
func GenerateExcelBySheets(sheets []SheetData) (*excelize.File, error) {
	f := excelize.NewFile()

	for _, sheet := range sheets {
		if _, err := f.NewSheet(sheet.SheetName); err != nil {
			return nil, err
		}

		for i, header := range sheet.Headers {
			if err := f.SetCellValue(sheet.SheetName, GetCellName(i, 1), header); err != nil {
				return nil, err
			}
		}

		baseIndex := 2
		if len(sheet.Headers) == 0 {
			baseIndex = 1
		}

		for i, row := range sheet.Rows {
			for j, val := range row {
				if err := f.SetCellValue(sheet.SheetName, GetCellName(j, baseIndex+i), val); err != nil {
					return nil, err
				}
			}
		}
	}

	if len(sheets) > 0 {
		f.SetActiveSheet(0)
	}

	return f, nil
}

// GetColumnName 获取列名 A-Z, AA-ZZ, AAA-ZZZ
func GetColumnName(col int) string {
	if col < 26 {
		return string(rune('A' + col))
	}

	return GetColumnName(col/26-1) + GetColumnName(col%26)
}

// GetCellName 获取单元格名称 A1, B2, AA1, AB1
func GetCellName(col, row int) string {
	return fmt.Sprintf("%s%d", GetColumnName(col), row)
}
相关推荐
第二只羽毛13 分钟前
C++ 高并发内存池1
大数据·开发语言·c++·开源
不想看见40420 分钟前
C++/Qt 实习岗位深度解析【结合一次研发实习谈感受】
开发语言·c++·qt
sjmaysee38 分钟前
Java框架SpringBoot(一)
java·开发语言·spring boot
寒秋花开曾相惜41 分钟前
(学习笔记)3.8 指针运算(3.8.3 嵌套的数组& 3.8.4 定长数组)
java·开发语言·笔记·学习·算法
想唱rap1 小时前
Linux线程
java·linux·运维·服务器·开发语言·mysql
Tony Bai1 小时前
Rust 看了流泪,AI 看了沉默:扒开 Go 泛型最让你抓狂的“残疾”类型推断
开发语言·人工智能·后端·golang·rust
njidf1 小时前
C++与Qt图形开发
开发语言·c++·算法
qwehjk20081 小时前
代码动态生成技术
开发语言·c++·算法
是翔仔呐1 小时前
第11章 显示外设驱动:I2C协议OLED屏、SPI协议LCD屏字符/图片/中文显示
c语言·开发语言·stm32·单片机·嵌入式硬件·学习·gitee
jason成都1 小时前
IoT 设备监控系统实战:基于 EMQX 的 MQTT 连接监控与数据格式指纹识别
开发语言·python