【Golang】go操作Excel基本操作-写入并保存

导入包

首先,安装github.com/tealeg/xlsx库。可以通过以下命令在终端中安装:

go get github.com/tealeg/xlsx

创建文件

指定好文件的名字

fileName := "D:\\a.xlsx"

再判断文件是否存在(这一步通常用于清空原来写入到excel的内容)

// 检查文件是否存在
	_, err1 := os.Stat(fileName)
	// 如果文件存在,删除文件
	if err1 == nil {
		err := os.Remove(fileName)
		if err != nil {
			log.Fatalf("删除文件失败: %v", err)
		}
	}

创建一个新的 Excel 文件

file := xlsx.NewFile()

添加表格

添加一个 Sheet

// 添加一个 Sheet
   sheet, err := file.AddSheet("Sheet1")
   if err != nil {
   	fmt.Printf("Error creating sheet: %s\n", err)
   	return
   }

添加行

表格中添加一行

//表格中添加一行
row := sheet.AddRow()

添加单元格

行中添加单元格并将值写入

cell := row.AddCell()
cell.SetValue(value)

保存文件

将文件保存到文件路径所在的位置

// 将 Excel 文件保存到本地
	if err := file.Save(fileName); err != nil {
		log.Fatal(err)
	}

封装

将上述内容封装成一个方法

package main

import (
	"fmt"
	"github.com/tealeg/xlsx"
	"log"
	"os"
)

func main() {

	fileName := "D:\\a.xlsx"
	// 检查文件是否存在
	_, err1 := os.Stat(fileName)
	// 如果文件存在,删除文件
	if err1 == nil {
		err := os.Remove(fileName)
		if err != nil {
			log.Fatalf("删除文件失败: %v", err)
		}
	}

	// 创建一个新的 Excel 文件
	file := xlsx.NewFile()
	// 添加一个 Sheet
	sheet, err := file.AddSheet("Sheet1")
	if err != nil {
		fmt.Printf("Error creating sheet: %s\n", err)
		return
	}
	// 写入数据到第一行的每一列
	data := []string{"Number", "time", "CPU/s"}
	// 添加一行
	row := sheet.AddRow()
	//写入数据到第一行的每一列
	for _, value := range data {
		cell := row.AddCell()
		cell.SetValue(value)
	}
	// 将 Excel 文件保存到本地
	if err := file.Save(fileName); err != nil {
		log.Fatal(err)
	}

	//添加一行到表格中
	newRow := sheet.AddRow()
	//当前的行依次添加单元格再把值放进去
	newRow.AddCell().SetValue("NO:1")
	newRow.AddCell().SetValue("2024-04-20 20:26:32")
	newRow.AddCell().SetValue("168s")
	// 最后将Excel文件保存到本地
	if err := file.Save(fileName); err != nil {
		log.Fatal(err)
	}
}
  • 10
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值