电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Golang生成Excel文檔的方法步驟

瀏覽:172日期:2022-07-13 08:53:45
目錄關于 Excelize 庫性能對比安裝創建 Excel 文檔實際場景復現創建工作表刪除默認創建的工作表合并單元格單元格樣式文字水平居中給單元格設置純色填充Style 結構體參考文檔

基于數據生成 Excel 文檔是一個很常見的需求,本文將介紹如何使用 Go 的 Excelize 庫去生成 Excel 文檔,以及一些具體場景下的代碼實現。

關于 Excelize 庫

Excelize 是 Go 語言編寫的用于操作 Office Excel 文檔基礎庫,基于 ECMA-376,ISO/IEC 29500 國際標準。可以使用它來讀取、寫入由 Microsoft Excel™ 2007 及以上版本創建的電子表格文檔。支持 XLSX / XLSM / XLTM / XLTX 等多種文檔格式,高度兼容帶有樣式、圖片(表)、透視表、切片器等復雜組件的文檔,并提供流式讀寫 API,用于處理包含大規模數據的工作簿。可應用于各類報表平臺、云計算、邊緣計算等系統。使用本類庫要求使用的 Go 語言為 1.15 或更高版本。

性能對比

下圖是一些主要的開源 Excel 庫在生成 12800*50 純文本矩陣時的性能對比(OS: macOS Mojave version 10.14.4, CPU: 3.4 GHz Intel Core i5, RAM: 16 GB 2400 MHz DDR4, HDD: 1 TB),包括 Go、Python、Java、PHP 和 NodeJS。

Golang生成Excel文檔的方法步驟

安裝

最新的版本是 v2.4.0:

go get github.com/360EntSecGroup-Skylar/excelize/v2創建 Excel 文檔

下面的案例中,我們創建了一個 Excel 文檔,并使用 NewSheet 方法新建了一個 Sheet2 工作表,Sheet1 是默認創建的工作表,然后我們使用 SetCellValue 方法分別在 Sheet2 工作表的 A2 單元格 和 Sheet1 表格的 B2 單元格設置值,并通過使用 SetActiveSheet 方法設置 Sheet2 工作表為默認的工作表,最終調用 SaveAs 方法將數據寫入 Excel 文檔中:

package mainimport ( 'fmt' 'github.com/360EntSecGroup-Skylar/excelize/v2')func main() { f := excelize.NewFile() // 創建一個工作表 index := f.NewSheet('Sheet2') // 設置單元格的值 f.SetCellValue('Sheet2', 'A2', 'Hello world.') f.SetCellValue('Sheet1', 'B2', 100) // 設置工作簿的默認工作表 f.SetActiveSheet(index) // 根據指定路徑保存文件 if err := f.SaveAs('Book1.xlsx'); err != nil {fmt.Println(err) }}實際場景復現創建工作表

工作表名稱是大小寫敏感的:

index := f.NewSheet('Sheet2')刪除默認創建的工作表

默認創建的 Excel 文檔是包含一個名為 Sheet1 的工作表,我們可能并不需要這個默認工作表,這個時候我們可以刪除這個工作表:

f.DeleteSheet('Sheet1')合并單元格

合并 Sheet1 工作表上 F1:I2 區域內的單元格:

excel.MergeCell('Sheet1', 'F1', 'I2')單元格樣式

給單元格設置樣式會經常遇到,比如設置單元格的背景顏色,Excelize 庫提供下面兩個方法進行設置單元格樣式(NewStyle 和 SetCellStyle):

// 通過給定的樣式格式 JSON 或結構體的指針創建樣式并返回樣式索引。// 請注意,顏色需要使用 RGB 色域代碼表示。style, err := f.NewStyle(`{ 'border': [ {'type': 'left','color': '0000FF','style': 3 }, {'type': 'top','color': '00FF00','style': 4 }, {'type': 'bottom','color': 'FFFF00','style': 5 }, {'type': 'right','color': 'FF0000','style': 6 }, {'type': 'diagonalDown','color': 'A020F0','style': 7 }, {'type': 'diagonalUp','color': 'A020F0','style': 8 }]}`)if err != nil { fmt.Println(err)}err = f.SetCellStyle('Sheet1', 'D7', 'D7', style)文字水平居中

文字水平居中需要用到 Alignment 樣式結構體:

type Alignment struct { Horizontal string `json:'horizontal'` Indent int `json:'indent'` JustifyLastLine bool `json:'justify_last_line'` ReadingOrder uint64 `json:'reading_order'` RelativeIndent int `json:'relative_indent'` ShrinkToFit bool `json:'shrink_to_fit'` TextRotation int `json:'text_rotation'` Verticalstring `json:'vertical'` WrapTextbool `json:'wrap_text'`}

水平居中只要設置 Horizontal 的值為 center 即可:

style, err := f.NewStyle(`{'alignment':{'horizontal':'center'}}`)if err != nil { fmt.Println(err)}err = excel.SetCellStyle('Sheet1', 'B1', 'B1', style)給單元格設置純色填充

給單元格填充顏色會使用到 Fill 樣式結構體:

type Fill struct { Type string `json:'type'` Pattern int `json:'pattern'` Color []string `json:'color'` Shading int `json:'shading'`}Style 結構體

從上面設置樣式的代碼中,我們可以發現 border 是一個數組,而 alignment 是一個結構體,這是由 Style 結構體決定的:

type Style struct { Border[]Border `json:'border'` Fill Fill`json:'fill'` Font *Font `json:'font'` Alignment *Alignment `json:'alignment'` Protection *Protection `json:'protection'` NumFmtint `json:'number_format'` DecimalPlaces int `json:'decimal_places'` CustomNumFmt *string `json:'custom_number_format'` Lang string `json:'lang'` NegRedbool`json:'negred'`}參考文檔

Excelize docs referenceTalks at Beijing Gopher Meetup

到此這篇關于Golang生成Excel文檔的方法步驟的文章就介紹到這了,更多相關Golang生成Excel內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: excel
相關文章:
主站蜘蛛池模板: 耐高温硅酸铝板-硅酸铝棉保温施工|亿欧建设工程 | 冷轧机|两肋冷轧机|扁钢冷轧机|倒立式拉丝机|钢筋拔丝机|收线机-巩义市华瑞重工机械制造有限公司 | 高压负荷开关-苏州雷尔沃电器有限公司| 量子管通环-自清洗过滤器-全自动反冲洗过滤器-沼河浸过滤器 | 金属软管_不锈钢金属软管_巩义市润达管道设备制造有限公司 | 电镀标牌_电铸标牌_金属标贴_不锈钢标牌厂家_深圳市宝利丰精密科技有限公司 | 安平县鑫川金属丝网制品有限公司,防风抑尘网,单峰防风抑尘,不锈钢防风抑尘网,铝板防风抑尘网,镀铝锌防风抑尘网 | 高压包-点火器-高压发生器-点火变压器-江苏天网 | 振动传感器,检波器-威海广达勘探仪器有限公司 | 阴离子_阳离子聚丙烯酰胺厂家_聚合氯化铝价格_水处理絮凝剂_巩义市江源净水材料有限公司 | 工程管道/塑料管材/pvc排水管/ppr给水管/pe双壁波纹管等品牌管材批发厂家-河南洁尔康建材 | 数控专用机床,专用机床,自动线,组合机床,动力头,自动化加工生产线,江苏海鑫机床有限公司 | 二手电脑回收_二手打印机回收_二手复印机回_硒鼓墨盒回收-广州益美二手电脑回收公司 | 工业电炉,台车式电炉_厂家-淄博申华工业电炉有限公司 | 长信科技产业园官网_西安厂房_陕西标准工业厂房 | 选矿设备,选矿生产线,选矿工艺,选矿技术-昆明昆重矿山机械 | 耐酸泵,耐酸泵厂家-淄博华舜耐腐蚀真空泵 | 考勤系统_人事考勤管理系统_本地部署BS考勤系统_考勤软件_天时考勤管理专家 | 土壤养分检测仪_肥料养分检测仪_土壤水分检测仪-山东莱恩德仪器 大型多片锯,圆木多片锯,方木多片锯,板材多片锯-祥富机械有限公司 | 皮带输送机-大倾角皮带输送机-皮带输送机厂家-河南坤威机械 | 台湾阳明固态继电器-奥托尼克斯光电传感器-接近开关-温控器-光纤传感器-编码器一级代理商江苏用之宜电气 | 517瓜水果特产网|一个专注特产好物的网站 | 青岛侦探调查_青岛侦探事务所_青岛调查事务所_青岛婚外情取证-青岛狄仁杰国际侦探公司 | 电缆接头_防水接头_电缆防水接头 - 乐清市新豪电气有限公司 | 除尘器布袋骨架,除尘器滤袋,除尘器骨架,电磁脉冲阀膜片,卸灰阀,螺旋输送机-泊头市天润环保机械设备有限公司 | LED太阳能中国结|发光红灯笼|灯杆造型灯|节日灯|太阳能灯笼|LED路灯杆装饰造型灯-北京中海轩光电 | 河南包装袋厂家_河南真空袋批发价格_河南服装袋定制-恒源达包装制品 | 比亚迪叉车-比亚迪电动叉车堆垛车托盘车仓储叉车价格多少钱报价 磁力去毛刺机_去毛刺磁力抛光机_磁力光饰机_磁力滚抛机_精密金属零件去毛刺机厂家-冠古科技 | 山东聚盛新型材料有限公司-纳米防腐隔热彩铝板和纳米防腐隔热板以及钛锡板、PVDF氟膜板供应商 | 成都APP开发-成都App定制-成都app开发公司-【未来久】 | 提升海外网站流量,增加国外网站访客UV,定制海外IP-访客王 | 济南品牌包装设计公司_济南VI标志设计公司_山东锐尚文化传播 | 万师讲师网-优质讲师培训师供应商,讲师认证,找讲师来万师 | 消防泵-XBD单级卧式/立式消防泵-上海塑泉泵阀(集团)有限公司 | 滚筒线,链板线,总装线,流水线-上海体能机电有限公司 | 电力测功机,电涡流测功机,磁粉制动器,南通远辰曳引机测试台 | 车充外壳,车载充电器外壳,车载点烟器外壳,点烟器连接头,旅行充充电器外壳,手机充电器外壳,深圳市华科达塑胶五金有限公司 | 塑料造粒机「厂家直销」-莱州鑫瑞迪机械有限公司 | 碳化硅,氮化硅,冰晶石,绢云母,氟化铝,白刚玉,棕刚玉,石墨,铝粉,铁粉,金属硅粉,金属铝粉,氧化铝粉,硅微粉,蓝晶石,红柱石,莫来石,粉煤灰,三聚磷酸钠,六偏磷酸钠,硫酸镁-皓泉新材料 | 不锈钢/气体/液体玻璃转子流量计(防腐,选型,规格)-常州天晟热工仪表有限公司【官网】 | 沈阳楼承板_彩钢板_压型钢板厂家-辽宁中盛绿建钢品股份有限公司 轴承振动测量仪电箱-轴承测振动仪器-测试仪厂家-杭州居易电气 |