欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > Golang操作excel的方法

Golang操作excel的方法

熱門標簽:福州鐵通自動外呼系統 澳門防封電銷卡 長沙ai機器人電銷 地圖標注測試 廣東語音外呼系統供應商 智能電銷機器人營銷 賺地圖標注的錢犯法嗎 濮陽自動外呼系統代理 烏魯木齊人工電銷機器人系統

關鍵術語介紹

為了方便開源庫的快速上手,我們先來了解 excel 中的幾個關鍵術語,如下圖所示,①為sheet,也就是表格中的頁簽;②為row,代表 excel 中的一行;③為cell,代表 excel 中的一個單元格。

正常情況下,創建一個表格的基本流程是打開 wps 點擊新建,這時會默認創建一個 sheet,然后在該 sheet 中的第一行填寫表頭,接下來根據表頭逐行填充內容,最后將文件另存為到硬盤的某個位置。這與 Golang 開源庫創建 excel 的流程基本相同,下面演示一個極簡表格的創建。

創建表格

創建表格前需要先引入 excel 庫,我們以比較熱門的 tealeg/xlsx 庫為例。

go get github.com/tealeg/xlsx

首先創建一個空文件,拿到文件句柄。

file := xlsx.NewFile()

創建一個名為人員信息收集的 sheet。

sheet, err := file.AddSheet("人員信息收集")
if err != nil {
 panic(err.Error())
}

然后為該 sheet 創建一行,這行作為我們的表頭。

row := sheet.AddRow()

在該行中創建一個單元格。

cell := row.AddCell()

現在給單元格填充內容,因為是表頭,暫且叫姓名

cell.Value = "姓名"

如何創建第二個單元格呢?原理相同,此處 cell 變量已定義,再創建新單元格只需賦值即可。

cell = row.AddCell()
cell.Value = "性別"

表頭已經設置好了,可以開始創建第二行來填充內容了,方式與上述無差別。

row = sheet.AddRow()
cell = row.AddCell()
cell.Value = "張三"
cell = row.AddCell()
cell.Value = "男"

表格設置完成后,將該文件保存,文件名可自定義。

err = file.Save("demo.xlsx")
if err != nil {
 panic(err.Error())
}

跑起來后,可以發現目錄中多了一個 demo.xlsx 文件,打開預覽內容如下,達到了預期效果。

文件源碼

package main

import "github.com/tealeg/xlsx"

func main() {
	file := xlsx.NewFile()
	sheet, err := file.AddSheet("人員信息收集")
	if err != nil {
		panic(err.Error())
	}
	row := sheet.AddRow()
	cell := row.AddCell()
	cell.Value = "姓名"
	cell = row.AddCell()
	cell.Value = "性別"

	row = sheet.AddRow()
	cell = row.AddCell()
	cell.Value = "張三"
	cell = row.AddCell()
	cell.Value = "男"

	err = file.Save("demo.xlsx")
	if err != nil {
		panic(err.Error())
	}
}

讀取表格

表格的讀取比創建簡單很多,依然以上文創建的文件為例。

output, err := xlsx.FileToSlice("demo.xlsx")
if err != nil {
 panic(err.Error())
}

只需將文件路徑傳入上述方法,即可自動讀取并返回一個三維切片,我們來讀取第一個 sheet 的第二行中的第一個單元格。

log.Println(output[0][1][1]) //Output: 男

由此一來就非常容易遍歷了。

for rowIndex, row := range output[0] {
 for cellIndex, cell := range row {
  log.Println(fmt.Sprintf("第%d行,第%d個單元格:%s", rowIndex+1, cellIndex+1, cell))
 }
}

2020/10/11 16:15:29 第1行,第1個單元格:姓名
2020/10/11 16:15:29 第1行,第2個單元格:性別
2020/10/11 16:15:29 第2行,第1個單元格:張三
2020/10/11 16:15:29 第2行,第2個單元格:男

文件源碼

package main

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

func main() {
	output, err := xlsx.FileToSlice("demo.xlsx")
	if err != nil {
		panic(err.Error())
	}
	log.Println(output[0][1][1])
	for rowIndex, row := range output[0] {
		for cellIndex, cell := range row {
			log.Println(fmt.Sprintf("第%d行,第%d個單元格:%s", rowIndex+1, cellIndex+1, cell))
		}
	}
}

 

修改表格

只是讀取表格內容可能在特定場景下無法滿足需求,有時候需要對表格內容進行更改。

file, err := xlsx.OpenFile("demo.xlsx")
if err != nil {
 panic(err.Error())
}

修改表格之前依然需要先讀取文件,只是這次并沒有直接將其轉化為三維切片。拿到文件句柄后,可以直接修改某一行的內容。

file.Sheets[0].Rows[1].Cells[0].Value = "李四"

上述代碼將第二行的張三改為了李四,但這還沒有結束,接下來需要將文件重新保存。

err = file.Save("demo.xlsx")
if err != nil {
 panic(err.Error())
}

打開文件預覽,可以看到已經成功將張三改為了李四。

文件源碼

package main

import "github.com/tealeg/xlsx"

func main() {
	file, err := xlsx.OpenFile("demo.xlsx")
	if err != nil {
		panic(err.Error())
	}
	file.Sheets[0].Rows[1].Cells[0].Value = "李四"
	err = file.Save("demo.xlsx")
	if err != nil {
		panic(err.Error())
	}
}

樣式設置

該開源庫不僅支持內容的編輯,還支持表格的樣式設置,樣式統一由結構體 Style 來負責。

type Style struct {
	Border     Border
	Fill      Fill
	Font      Font
	ApplyBorder   bool
	ApplyFill    bool
	ApplyFont    bool
	ApplyAlignment bool
	Alignment    Alignment
	NamedStyleIndex *int
}

拿上述生成的文件為例,假如我要將姓名所在單元格居中,首先要實例化樣式對象。

style := xlsx.NewStyle()

賦值居中屬性。

style.Alignment = xlsx.Alignment{
 Horizontal:  "center",
 Vertical:   "center",
}

給第一行第一個單元格設置樣式。

file.Sheets[0].Rows[0].Cells[0].SetStyle(style)

與修改表格處理邏輯相同,最后保存文件。

err = file.Save("demo.xlsx")
if err != nil {
 panic(err.Error())
}

打開預覽,可以看到文字已經上下左右居中。

同理,可以修改文字顏色和背景,同樣通過 style 的屬性來設置。

style.Font.Color = xlsx.RGB_Dark_Red
style.Fill.BgColor = xlsx.RGB_Dark_Green

其他還有很多屬性可以設置,比如合并單元格、字體、大小等等,大家可以自行測試。

文件源碼

package main

import "github.com/tealeg/xlsx"

func main() {
	file, err := xlsx.OpenFile("demo.xlsx")
	if err != nil {
		panic(err.Error())
	}
	style := xlsx.NewStyle()
	style.Font.Color = xlsx.RGB_Dark_Red
	style.Fill.BgColor = xlsx.RGB_Dark_Green
	style.Alignment = xlsx.Alignment{
		Horizontal:  "center",
		Vertical:   "center",
	}
	file.Sheets[0].Rows[0].Cells[0].SetStyle(style)
	err = file.Save("demo.xlsx")
	if err != nil {
		panic(err.Error())
	}
}

我是平也,這有一個專注Gopher技術成長的開源項目「go home」

到此這篇關于Golang操作excel的方法的文章就介紹到這了,更多相關Golang操作excel內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Golang讀寫Excel的方法教程
  • golang與PHP輸出excel示例

標簽:慶陽 太原 德州 廣西 貴陽 阿克蘇 調研邀請 西雙版納

巨人網絡通訊聲明:本文標題《Golang操作excel的方法》,本文關鍵詞  Golang,操作,excel,的,方法,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Golang操作excel的方法》相關的同類信息!
  • 本頁收集關于Golang操作excel的方法的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    欧美精品自拍偷拍动漫精品| 色菇凉天天综合网| 极品粉嫩小仙女高潮喷水久久 | av在线不卡免费看| 国产剧情一区二区三区| 国产精品资源在线| 成人激情文学综合网| 99精品1区2区| www.超碰97| 99久久久无码国产精品不卡| 国产精品18在线| 国产va在线播放| 在线不卡一区二区| 精品av综合导航| 专区另类欧美日韩| 午夜天堂影视香蕉久久| 韩国理伦片一区二区三区在线播放| 国产原创一区二区三区| av亚洲精华国产精华| 日韩精品一区二区三区高清免费| 干b视频在线观看| 色哦色哦哦色天天综合| 国产精品一区一区| 蜜桃av一区二区三区| 国产精品一二三四区| 一区二区在线免费观看视频| 国产夫妻性爱视频| 成人免费视频网站入口::| 欧美性xxxxx极品少妇| 精品国产乱码久久| 亚洲三级在线播放| 国产精品18久久久久久久久| 亚洲一卡二卡三卡四卡无卡久久 | 亚洲国产精品视频| 国模一区二区三区白浆| av天堂一区二区| 久久国产波多野结衣| 欧美大白屁股肥臀xxxxxx| 亚洲婷婷综合久久一本伊一区 | 久久新电视剧免费观看| 亚洲综合小说图片| 成人精品一区二区三区中文字幕| www.久久av| 日韩一级免费一区| 亚洲一二三区在线观看| 99国产精品一区| 色综合久久综合中文综合网| 久久久不卡影院| 精东粉嫩av免费一区二区三区| 800av在线播放| 欧美一区二视频| 午夜伊人狠狠久久| 成人性生活免费看| 日韩一级片网址| 久久成人18免费观看| 在线观看福利片| 精品久久人人做人人爱| 午夜精品在线视频一区| 在线观看国产网站| 日韩精品中文字幕一区二区三区| 日产欧产美韩系列久久99| 中文字幕 亚洲一区| 精品久久久久久久人人人人传媒| 日本午夜精品一区二区三区电影| 成年人网站免费在线观看| 精品国产免费一区二区三区四区 | 亚洲 欧美 变态 另类 综合| 中文久久乱码一区二区| 高清不卡在线观看av| 色婷婷精品久久二区二区蜜臀av| 一个色综合av| 精品人妻一区二区三区日产乱码卜| 日韩欧美一二三区| 国产一区二区网址| 欧美揉bbbbb揉bbbbb| 日韩**一区毛片| 26uuu成人网| 亚洲一区二区三区四区在线 | 91丝袜高跟美女视频| 91精品国产麻豆| 国产成人精品亚洲午夜麻豆| 91成人免费网站| 久久精品噜噜噜成人av农村| 国产午夜手机精彩视频| 亚洲电影你懂得| 国产精品一区二区亚洲| 亚洲国产wwwccc36天堂| 成人欧美一区二区三区黑人一| 亚洲精品一二三区| 91免费在线看片| 日韩有码一区二区三区| 日韩精品免费视频人成| 日日操免费视频| 午夜精品久久久久久久久久| 欧美一级片在线视频| 精品盗摄一区二区三区| 国产毛片精品国产一区二区三区| 青椒成人免费视频| 人妻人人澡人人添人人爽| 日韩黄色一级片| 欧美在线色视频| 国产成人精品一区二| 欧美白人最猛性xxxxx69交| 少妇丰满尤物大尺度写真| 国产精品视频一二三区| 91视频免费在观看| 免费国产亚洲视频| 欧美一级欧美一级在线播放| 少妇丰满尤物大尺度写真| 1024国产精品| 国产免费无码一区二区视频| 国产成人日日夜夜| 国产精品热久久久久夜色精品三区| 久久日韩精品一区二区五区| 欧美精品九九99久久| 91色视频在线| 亚洲一区二区影院| 老湿机69福利| 日韩亚洲欧美在线观看| 香蕉视频污视频| 午夜电影网亚洲视频| 欧美成人一区二区三区片免费| 在线免费观看污视频| 日本最新不卡在线| 精品久久国产老人久久综合| 亚洲一区二区三区蜜桃| 中文字幕在线播放视频| 天天av天天翘天天综合网色鬼国产| 在线观看91av| 国产精品免费无码| 国产成人日日夜夜| 洋洋av久久久久久久一区| 欧美福利视频导航| 阿v天堂2014| 99精品久久99久久久久| 日韩电影免费在线观看网站| 久久综合九色综合97婷婷| 一区二区视频免费看| yjizz视频| 国产成a人亚洲精| 一区二区三区久久| 久久亚洲一区二区三区四区| 极品久久久久久| 自拍偷拍亚洲天堂| 成人av资源下载| 美女视频黄免费的久久| 亚洲欧美影音先锋| 2020国产成人综合网| 欧美日韩一区二区三区视频| 国产123在线| 扒开伸进免费视频| 国产精品亚洲一区二区三区在线 | 久久爱一区二区| 国产乱码精品一品二品| 亚洲成人精品一区| 国产精品欧美综合在线| 欧美一三区三区四区免费在线看| 天堂а√在线中文在线鲁大师| 亚洲免费观看在线| 99久久久精品免费观看国产蜜| 欧美最猛性xxxxx直播| 九九九视频在线观看| 污污免费在线观看| 精品无码av一区二区三区不卡| 国产成人aaa| 久久99精品久久久久久动态图 | 成av人片一区二区| 久久er99热精品一区二区| 五月天一区二区三区| 亚洲精品久久7777| 亚洲男人天堂一区| 亚洲视频一区二区在线观看| 国产精品沙发午睡系列990531| 国产网站一区二区三区| 久久日一线二线三线suv| 久久久久青草大香线综合精品| 欧美电影免费观看完整版| 日韩亚洲国产中文字幕欧美| 中文字幕一区二区久久人妻网站| 精品99一区二区| 欧美一级高清大全免费观看| 69堂国产成人免费视频| 欧美视频在线一区| 欧美卡1卡2卡| 欧美一区二区观看视频| 欧美一区二区三区日韩| 欧美大片免费久久精品三p| 久久久久久久久岛国免费| 国产三级欧美三级| 亚洲三级在线免费观看| 一区二区三区国产精华| 亚洲精品国产精华液| 日日夜夜免费精品| 精品一区二区久久久| wwwww黄色| 日本高清免费不卡视频| 欧美精品视频www在线观看| 欧美成人aa大片| 国产精品色哟哟网站| 天天av天天翘天天综合网色鬼国产|