校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > Golang生成Excel文檔的方法步驟

Golang生成Excel文檔的方法步驟

熱門標簽:如何利用高德地圖標注家 上海企業外呼系統排名 揚州電銷外呼系統軟件 武漢百應人工智能電銷機器人 400手機電話免費辦理 百度地圖標注位置網站 電腦外呼系統輻射大嗎 開通400電話申請流程 智能語音電銷的機器人

基于數據生成 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。

安裝

最新的版本是 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 main

import (
    "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"`
    Vertical        string `json:"vertical"`
    WrapText        bool   `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"`
    NumFmt        int         `json:"number_format"`
    DecimalPlaces int         `json:"decimal_places"`
    CustomNumFmt  *string     `json:"custom_number_format"`
    Lang          string      `json:"lang"`
    NegRed        bool        `json:"negred"`
}

參考文檔

Excelize docs reference
Talks at Beijing Gopher Meetup

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

您可能感興趣的文章:
  • Golang讀寫Excel的方法教程
  • Go語言導出內容到Excel的方法
  • 在django項目中導出數據到excel文件并實現下載的功能
  • python如何實現excel數據添加到mongodb
  • Django 導出 Excel 代碼的實例詳解
  • django使用xlwt導出excel文件實例代碼
  • Golang操作excel的方法
  • golang與PHP輸出excel示例

標簽:延邊 宜賓 黑龍江 嘉峪關 新余 武漢 江西 張掖

巨人網絡通訊聲明:本文標題《Golang生成Excel文檔的方法步驟》,本文關鍵詞  Golang,生成,Excel,文檔,的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Golang生成Excel文檔的方法步驟》相關的同類信息!
  • 本頁收集關于Golang生成Excel文檔的方法步驟的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    国产精品中文字幕日韩精品| 久久伊99综合婷婷久久伊| 中文字幕一区二区三区在线不卡| 国产综合色在线视频区| 亚洲精品一区在线观看| 国产米奇在线777精品观看| 久久久久久毛片| 成人免费视频一区二区| 中文字幕日本乱码精品影院| 99re8在线精品视频免费播放| 亚洲精品中文在线影院| 欧美美女直播网站| 韩国av一区二区三区| 中文字幕亚洲区| 欧洲亚洲精品在线| 免费在线视频一区| 中文乱码免费一区二区 | 蜜臀av性久久久久蜜臀aⅴ流畅| 欧美一级理论片| 国产成人精品一区二区三区四区| 亚洲欧洲制服丝袜| 日韩午夜在线观看视频| 成人性视频网站| 亚洲国产欧美另类丝袜| 欧美成人午夜电影| av不卡免费电影| 午夜久久电影网| 久久久另类综合| 欧美综合欧美视频| 国产激情视频一区二区在线观看| 亚洲免费观看高清在线观看| 欧美丰满一区二区免费视频 | 91精品黄色片免费大全| 国产在线看一区| 亚洲免费观看在线视频| www久久久久| 欧美性欧美巨大黑白大战| 国内成人精品2018免费看| 亚洲精品视频自拍| 精品少妇一区二区三区视频免付费 | 成人黄色在线看| 天堂成人国产精品一区| 中文字幕在线免费不卡| 日韩一级二级三级精品视频| 99re这里只有精品首页| 精品一区二区三区香蕉蜜桃| 亚洲色图视频网站| 久久日韩精品一区二区五区| 欧美自拍偷拍一区| 成人一区在线观看| 久久91精品国产91久久小草| 亚洲一区二区三区免费视频| 欧美国产日韩在线观看| 精品久久久久久久久久久院品网| 欧美中文字幕久久| 99久久777色| 国产69精品一区二区亚洲孕妇| 日韩av网站免费在线| 亚洲在线视频一区| ●精品国产综合乱码久久久久| 久久综合色婷婷| 欧美一区二区三区免费在线看| 色婷婷一区二区| 99r国产精品| 成人动漫在线一区| 国产乱淫av一区二区三区| 蜜桃av一区二区三区电影| 亚洲国产aⅴ天堂久久| 一区二区三区免费| 中文字幕五月欧美| 中文一区在线播放| 中文字幕欧美三区| 国产午夜精品美女毛片视频| xvideos.蜜桃一区二区| 2019国产精品| 久久久午夜电影| 国产女同互慰高潮91漫画| 久久精品一区四区| 国产欧美中文在线| 欧美激情一区二区三区在线| 国产人伦精品一区二区| 国产蜜臀av在线一区二区三区| 久久久国产精品午夜一区ai换脸| 精品卡一卡二卡三卡四在线| 精品国产免费视频| 国产亚洲一区二区三区四区| 久久免费美女视频| 国产精品国产自产拍在线| 中文字幕不卡三区| 亚洲日本中文字幕区| 亚洲免费av高清| 亚洲一区二区视频在线| 人人爽香蕉精品| 国产一本一道久久香蕉| av网站一区二区三区| 色欧美乱欧美15图片| 欧美亚洲精品一区| 日韩色视频在线观看| www成人在线观看| 国产精品三级av| 洋洋成人永久网站入口| 老司机精品视频导航| 丁香激情综合国产| 日本久久一区二区| 日韩一级黄色大片| 中文字幕av一区二区三区免费看| 亚洲欧美韩国综合色| 日韩av电影免费观看高清完整版| 久久精工是国产品牌吗| 波多野结衣在线aⅴ中文字幕不卡| 97久久精品人人爽人人爽蜜臀| 欧美日高清视频| 337p日本欧洲亚洲大胆精品| 中文字幕在线不卡一区| 午夜在线电影亚洲一区| 国产乱码精品1区2区3区| 91亚洲精品久久久蜜桃| 日韩精品一区国产麻豆| 国产精品区一区二区三区| 午夜视频在线观看一区| 国产精品99久久久久久久女警| 欧美在线视频日韩| 国产亚洲欧美激情| 午夜伦欧美伦电影理论片| 国产成人无遮挡在线视频| 欧美色图天堂网| 国产日本一区二区| 免费在线观看视频一区| 99视频在线观看一区三区| 精品久久久久久亚洲综合网 | 欧美日韩一级二级| 国产欧美精品一区二区色综合 | 亚洲女性喷水在线观看一区| 蜜桃久久精品一区二区| 91麻豆精东视频| 26uuu亚洲综合色| 午夜久久久久久| 色综合久久88色综合天天6| 精品久久一区二区三区| 污片在线观看一区二区| 大胆欧美人体老妇| 欧美成人精品福利| 午夜久久电影网| 91免费观看视频| 欧美激情一区三区| 精品一区二区在线免费观看| 欧美色倩网站大全免费| 日韩理论片网站| 夫妻av一区二区| 久久精品夜色噜噜亚洲aⅴ| 免费在线观看一区二区三区| 欧美日本精品一区二区三区| 日韩一区欧美一区| 成人黄色电影在线| 欧美国产综合色视频| 韩日精品视频一区| 日韩女优毛片在线| 日韩av中文字幕一区二区| 欧美喷潮久久久xxxxx| 亚洲第一福利一区| 欧美日韩电影在线播放| 婷婷国产在线综合| 91精品一区二区三区久久久久久| 午夜欧美视频在线观看| 717成人午夜免费福利电影| 香蕉成人啪国产精品视频综合网 | ●精品国产综合乱码久久久久| 成人午夜免费av| 国产精品久久久久影视| 99热这里都是精品| 亚洲精品日日夜夜| 欧美性猛片aaaaaaa做受| 亚洲第一成年网| 欧美一区二区三区免费在线看| 日韩av一二三| 久久久三级国产网站| 顶级嫩模精品视频在线看| 国产午夜精品一区二区| 成人一级视频在线观看| 国产成人精品免费视频网站| 国产精品色婷婷久久58| 成人午夜视频在线| 精品国产电影一区二区| 毛片av中文字幕一区二区| 欧美一级欧美一级在线播放| 亚洲精品免费播放| 欧美一区二区三区小说| 亚洲444eee在线观看| 欧美日韩一区中文字幕| 亚洲激情在线播放| 欧美在线观看视频一区二区| 亚洲综合成人在线视频| 欧美性猛片xxxx免费看久爱| 亚洲一区二区三区视频在线播放| av网站一区二区三区| 肉丝袜脚交视频一区二区| 91精品国产综合久久久久久久久久| 午夜精品一区二区三区免费视频| xf在线a精品一区二区视频网站| 国产一区二区三区在线观看免费|