婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > Golang操作excel的方法

Golang操作excel的方法

熱門(mén)標(biāo)簽:福州鐵通自動(dòng)外呼系統(tǒng) 澳門(mén)防封電銷卡 長(zhǎng)沙ai機(jī)器人電銷 地圖標(biāo)注測(cè)試 廣東語(yǔ)音外呼系統(tǒng)供應(yīng)商 智能電銷機(jī)器人營(yíng)銷 賺地圖標(biāo)注的錢(qián)犯法嗎 濮陽(yáng)自動(dòng)外呼系統(tǒng)代理 烏魯木齊人工電銷機(jī)器人系統(tǒng)

關(guān)鍵術(shù)語(yǔ)介紹

為了方便開(kāi)源庫(kù)的快速上手,我們先來(lái)了解 excel 中的幾個(gè)關(guān)鍵術(shù)語(yǔ),如下圖所示,①為sheet,也就是表格中的頁(yè)簽;②為row,代表 excel 中的一行;③為cell,代表 excel 中的一個(gè)單元格。

正常情況下,創(chuàng)建一個(gè)表格的基本流程是打開(kāi) wps 點(diǎn)擊新建,這時(shí)會(huì)默認(rèn)創(chuàng)建一個(gè) sheet,然后在該 sheet 中的第一行填寫(xiě)表頭,接下來(lái)根據(jù)表頭逐行填充內(nèi)容,最后將文件另存為到硬盤(pán)的某個(gè)位置。這與 Golang 開(kāi)源庫(kù)創(chuàng)建 excel 的流程基本相同,下面演示一個(gè)極簡(jiǎn)表格的創(chuàng)建。

創(chuàng)建表格

創(chuàng)建表格前需要先引入 excel 庫(kù),我們以比較熱門(mén)的 tealeg/xlsx 庫(kù)為例。

go get github.com/tealeg/xlsx

首先創(chuàng)建一個(gè)空文件,拿到文件句柄。

file := xlsx.NewFile()

創(chuàng)建一個(gè)名為人員信息收集的 sheet。

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

然后為該 sheet 創(chuàng)建一行,這行作為我們的表頭。

row := sheet.AddRow()

在該行中創(chuàng)建一個(gè)單元格。

cell := row.AddCell()

現(xiàn)在給單元格填充內(nèi)容,因?yàn)槭潜眍^,暫且叫姓名

cell.Value = "姓名"

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

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

表頭已經(jīng)設(shè)置好了,可以開(kāi)始創(chuàng)建第二行來(lái)填充內(nèi)容了,方式與上述無(wú)差別。

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

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

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

跑起來(lái)后,可以發(fā)現(xiàn)目錄中多了一個(gè) demo.xlsx 文件,打開(kāi)預(yù)覽內(nèi)容如下,達(dá)到了預(yù)期效果。

文件源碼

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

讀取表格

表格的讀取比創(chuàng)建簡(jiǎn)單很多,依然以上文創(chuàng)建的文件為例。

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

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

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

由此一來(lái)就非常容易遍歷了。

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

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

文件源碼

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個(gè)單元格:%s", rowIndex+1, cellIndex+1, cell))
		}
	}
}

 

修改表格

只是讀取表格內(nèi)容可能在特定場(chǎng)景下無(wú)法滿足需求,有時(shí)候需要對(duì)表格內(nèi)容進(jìn)行更改。

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

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

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

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

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

打開(kāi)文件預(yù)覽,可以看到已經(jīng)成功將張三改為了李四。

文件源碼

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

樣式設(shè)置

該開(kāi)源庫(kù)不僅支持內(nèi)容的編輯,還支持表格的樣式設(shè)置,樣式統(tǒng)一由結(jié)構(gòu)體 Style 來(lái)負(fù)責(zé)。

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

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

style := xlsx.NewStyle()

賦值居中屬性。

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

給第一行第一個(gè)單元格設(shè)置樣式。

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

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

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

打開(kāi)預(yù)覽,可以看到文字已經(jīng)上下左右居中。

同理,可以修改文字顏色和背景,同樣通過(guò) style 的屬性來(lái)設(shè)置。

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

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

文件源碼

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

我是平也,這有一個(gè)專注Gopher技術(shù)成長(zhǎng)的開(kāi)源項(xiàng)目「go home」

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

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

標(biāo)簽:慶陽(yáng) 太原 德州 廣西 貴陽(yáng) 阿克蘇 調(diào)研邀請(qǐng) 西雙版納

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Golang操作excel的方法》,本文關(guān)鍵詞  Golang,操作,excel,的,方法,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Golang操作excel的方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Golang操作excel的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    91视频免费看| 国产精品网友自拍| av网站免费线看精品| jlzzjlzz亚洲女人18| 一本到不卡免费一区二区| 精品视频1区2区3区| 国产精品丝袜久久久久久app| 久久久国际精品| 亚洲欧美综合在线精品| 亚洲小说欧美激情另类| 美女精品自拍一二三四| 丁香六月久久综合狠狠色| 色婷婷国产精品| 日韩欧美国产wwwww| 中文字幕一区二区三区蜜月| 亚洲网友自拍偷拍| 国产精品一区二区视频| 色av一区二区| 久久久欧美精品sm网站| 亚洲国产成人91porn| 国产乱理伦片在线观看夜一区| 在线看日本不卡| 国产网站一区二区| 天堂影院一区二区| 成人av在线看| 日韩午夜在线播放| 亚洲精品美腿丝袜| 国产精品资源在线观看| 欧美日韩大陆一区二区| 国产精品蜜臀av| 久久不见久久见中文字幕免费| 色婷婷久久综合| 国产日韩欧美精品综合| 日本三级亚洲精品| 在线日韩一区二区| 国产精品三级久久久久三级| 日韩精品91亚洲二区在线观看| 99久久婷婷国产综合精品电影| 欧美精品一区二区三区高清aⅴ| 亚洲色图制服丝袜| 国产成人免费视频一区| 欧美成人猛片aaaaaaa| 亚洲午夜免费福利视频| 91丨porny丨在线| 国产日韩欧美精品在线| 国产综合成人久久大片91| 欧美精品v国产精品v日韩精品| 国产精品国产精品国产专区不片| 国内精品国产成人| 欧美成人vps| 久久狠狠亚洲综合| 欧美一区二区三区性视频| 亚洲一区二区三区不卡国产欧美| 不卡视频在线观看| 欧美激情资源网| 国产精品一二三四| 精品国产乱码久久久久久1区2区| 免费久久99精品国产| 欧美日本韩国一区二区三区视频| 亚洲视频一区二区在线| 色哟哟精品一区| 亚洲色图视频免费播放| 国产 欧美在线| 国产精品视频在线看| 国产成人精品免费| 中文字幕永久在线不卡| 欧美一区二区三区四区视频| 亚洲自拍偷拍av| 欧洲av在线精品| 亚洲国产日韩综合久久精品| 在线观看亚洲精品视频| 亚洲国产日韩a在线播放性色| 欧美日高清视频| 日本在线观看不卡视频| 精品国产第一区二区三区观看体验| 免费高清成人在线| 337p日本欧洲亚洲大胆色噜噜| 国产一区二区三区免费看| 中文字幕欧美日本乱码一线二线 | 日韩三级电影网址| 蜜桃传媒麻豆第一区在线观看| 日韩欧美一区电影| 国产99精品国产| 亚洲人成网站影音先锋播放| 在线视频欧美区| 日韩二区三区在线观看| 精品伦理精品一区| 成人午夜看片网址| 综合久久给合久久狠狠狠97色| 色噜噜偷拍精品综合在线| 五月激情综合色| 日韩久久免费av| av在线播放一区二区三区| 亚洲一区二区三区四区的 | 欧美国产欧美综合| 91在线无精精品入口| 午夜国产精品一区| 久久久久久久久蜜桃| 一本色道久久加勒比精品| 婷婷久久综合九色综合绿巨人| 精品少妇一区二区三区在线播放 | 琪琪一区二区三区| 久久久91精品国产一区二区精品 | 国产99久久久久| 一区二区三区免费观看| 欧美va在线播放| 色综合久久久网| 久草精品在线观看| 亚洲最快最全在线视频| 久久久久88色偷偷免费| 欧美在线观看18| 国产精品99久久久久久似苏梦涵| 一区二区三区国产精华| 久久综合九色综合久久久精品综合| 色婷婷激情综合| 国产99久久久国产精品潘金| 午夜国产精品影院在线观看| 中文字幕一区视频| 久久综合狠狠综合久久综合88| 在线观看日产精品| av中文字幕不卡| 国产精品一区二区不卡| 毛片一区二区三区| 亚洲成人自拍一区| 亚洲欧美日韩在线| 欧美激情综合五月色丁香| 日韩欧美精品在线视频| 国产网站一区二区三区| 日韩一区二区影院| 欧美视频一区二| 色偷偷一区二区三区| 懂色av中文一区二区三区| 麻豆精品在线播放| 日本成人在线电影网| 亚洲精品国产无套在线观| 国产精品久久毛片| 久久久久国产精品麻豆| 精品三级在线观看| 欧美不卡视频一区| 精品国产免费久久| 91精品国产欧美一区二区18| 欧美午夜精品一区二区三区| 91老司机福利 在线| 不卡大黄网站免费看| 国产99精品国产| 成人精品一区二区三区中文字幕| 国产精品自在欧美一区| 国产另类ts人妖一区二区| 国产麻豆日韩欧美久久| 国产乱码一区二区三区| 国产麻豆精品theporn| 国产一区二区三区免费| 国产最新精品精品你懂的| 极品美女销魂一区二区三区免费| 理论电影国产精品| 国内精品写真在线观看| 久久成人免费日本黄色| 国产乱子伦视频一区二区三区 | 极品美女销魂一区二区三区免费| 日本vs亚洲vs韩国一区三区二区| 日本亚洲免费观看| 日本aⅴ亚洲精品中文乱码| 奇米精品一区二区三区在线观看一 | 欧美性xxxxx极品少妇| 欧美性xxxxxx少妇| 欧美一区午夜视频在线观看| 欧美一级片免费看| 久久影院视频免费| 亚洲视频一区二区免费在线观看| 亚洲最新在线观看| 秋霞av亚洲一区二区三| 精品影院一区二区久久久| 国产精品一区一区| 色老综合老女人久久久| 欧美日韩一区成人| 久久精品亚洲乱码伦伦中文| 亚洲乱码国产乱码精品精的特点| 亚洲国产一区视频| 国产高清无密码一区二区三区| 成人久久18免费网站麻豆| 欧美日韩另类一区| 国产日韩影视精品| 亚洲一区二区三区视频在线| 国产麻豆9l精品三级站| 欧美午夜电影网| 国产欧美日韩在线观看| 天堂蜜桃91精品| eeuss影院一区二区三区| 欧美一区二区精品在线| 中文字幕综合网| 另类专区欧美蜜桃臀第一页| 色欧美片视频在线观看| 久久久久久久性| 日韩不卡一二三区| 色天天综合久久久久综合片| 久久夜色精品国产欧美乱极品| 亚洲综合久久av| 成人精品视频.| 日韩欧美国产综合| 一区二区三区日本|