【Go】excelize库实现excel导入导出封装,基于excel模板导出excel




package main
 
import (
    "fmt"
    "github.com/xuri/excelize/v2"
    "os"
)
 
// 根据模板导出Excel
func ExportExcelByTemplate(filename string, sheetName string, rows [][]interface{}) error {
    // 打开模板文件
    f, err := excelize.OpenFile(filename)
    if err != nil {
        return err
    }
 
    // 获取模板中的工作表
    index := f.GetSheetIndex(sheetName)
    if index == -1 {
        return fmt.Errorf("工作表 %s 不存在", sheetName)
    }
 
    // 根据模板创建新的工作表
    newSheetIndex := f.NewSheetAfter("模板", "导出", excelize.SheetStateVisible)
 
    // 复制模板内容到新工作表
    if err := f.CopySheet(index, newSheetIndex); err != nil {
        return err
    }
 
    // 填充数据到新工作表
    for _, row := range rows {
        if err := f.SetSheetRow("导出", "A"+fmt.Sprintf("%d", len(row)+1), &row); err != nil {
            return err
        }
    }
 
    // 保存文件
    if err := f.SaveAs(filename); err != nil {
        return err
    }
 
    return nil
}
 
func main() {
    // 模拟数据
    data := [][]interface{}{
        {1, "张三", 25},
        {2, "李四", 30},
    }
 
    // 调用函数导出Excel
    if err := ExportExcelByTemplate("template.xlsx", "模板", data); err != nil {
        fmt.Fprintf(os.Stderr, "导出失败: %v\n", err)
    } else {
        fmt.Println("导出成功")
    }
}

这段代码首先定义了一个ExportExcelByTemplate函数,该函数接受模板文件名、工作表名和数据切片作为参数。它打开模板文件,获取模板的工作表,然后创建一个新的工作表,并将模板的内容复制到新工作表中。接着,它遍历数据切片,将每行数据填充到新工作表的相应位置。最后,它保存文件。在main函数中,我们模拟了一些数据并调用了ExportExcelByTemplate函数来导出Excel文件。

最后修改于:2024年08月23日 10:19

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日