亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Go?Excelize?API源碼閱讀SetSheetViewOptions示例解析

 更新時間:2022年08月17日 17:09:32   作者:丘山子  
這篇文章主要為大家介紹了Go-Excelize?API源碼閱讀SetSheetViewOptions示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

一、Go-Excelize簡介

Excelize 是 Go 語言編寫的用于操作 Office Excel 文檔基礎(chǔ)庫,基于 ECMA-376,ISO/IEC 29500 國際標(biāo)準(zhǔn)。

可以使用它來讀取、寫入由 Microsoft Excel™ 2007 及以上版本創(chuàng)建的電子表格文檔。

支持 XLAM / XLSM / XLSX / XLTM / XLTX 等多種文檔格式,高度兼容帶有樣式、圖片(表)、透視表、切片器等復(fù)雜組件的文檔,并提供流式讀寫 API,用于處理包含大規(guī)模數(shù)據(jù)的工作簿。

可應(yīng)用于各類報表平臺、云計算、邊緣計算等系統(tǒng)。使用本類庫要求使用的 Go 語言為 1.15 或更高版本。

二、 SetSheetViewOptions

func (f *File) SetSheetViewOptions(sheet string, viewIndex int, opts ...SheetViewOption) error

根據(jù)給定的工作表名稱、視圖索引和視圖參數(shù)設(shè)置工作表視圖屬性,viewIndex 可以是負(fù)數(shù),如果是這樣,則向后計數(shù)(-1 代表最后一個視圖)。

可選視圖參數(shù)類型
DefaultGridColorbool
ShowFormulasbool
ShowGridLinesbool
ShowRowColHeadersbool
ShowZerosbool
RightToLeftbool
ShowRulerbool
Viewstring
TopLeftCellstring
ZoomScalefloat64

下面是一個該API的使用例子:

f := excelize.NewFile()
const sheet = "Sheet1"
if err := f.SetSheetViewOptions(sheet, 0,
    excelize.DefaultGridColor(false),
    excelize.ShowFormulas(true),
    excelize.ShowGridLines(true),
    excelize.ShowRowColHeaders(true),
    excelize.RightToLeft(false),
    excelize.ShowRuler(false),
    excelize.View("pageLayout"),
    excelize.TopLeftCell("C3"),
    excelize.ZoomScale(80),
); err != nil {
    fmt.Println(err)
}
var zoomScale ZoomScale
fmt.Println("Default:")
fmt.Println("- zoomScale: 80")
if err := f.SetSheetViewOptions(sheet, 0, excelize.ZoomScale(500)); err != nil {
    fmt.Println(err)
}
if err := f.GetSheetViewOptions(sheet, 0, &zoomScale); err != nil {
    fmt.Println(err)
}
fmt.Println("Used out of range value:")
fmt.Println("- zoomScale:", zoomScale)
if err := f.SetSheetViewOptions(sheet, 0, excelize.ZoomScale(123)); err != nil {
    fmt.Println(err)
}
if err := f.GetSheetViewOptions(sheet, 0, &zoomScale); err != nil {
    fmt.Println(err)
}
fmt.Println("Used correct value:")
fmt.Println("- zoomScale:", zoomScale)

其輸出結(jié)果如下:

Default:
- zoomScale: 80
Used out of range value:
- zoomScale: 80
Used correct value:
- zoomScale: 123

廢話少說,直接上源碼:

func (f *File) SetSheetViewOptions(name string, viewIndex int, opts ...SheetViewOption) error {
	view, err := f.getSheetView(name, viewIndex)
	if err != nil {
		return err
	}
	for _, opt := range opts {
		opt.setSheetViewOption(view)
	}
	return nil
}

先根據(jù)工作表視圖的索引取工作表視圖。

這個函數(shù)其實邏輯很簡單,就是判斷下標(biāo)是不是合法的,然后直接返回就是的了,如果默認(rèn)下標(biāo)是合法的,那么都不需要這個函數(shù)了直接ws.SheetViews.SheetView[viewIndex].

然后再遍歷不定長參數(shù)opts

	for _, opt := range opts {
		opt.setSheetViewOption(view)
	}

opt都是SheetViewOption interface類型,其下有一個函數(shù)。

  • setSheetViewOption(view *xlsxSheetView)

此處我們使用的是這個函數(shù)....

邏輯都很簡單,就是將傳來的值處理成工作表視圖屬性能夠設(shè)置的值。

然后直接賦值傳遞過去。

下面介紹一下這些參數(shù)的含義:

  • DefaultGridColor是一個SheetViewOption。它指定一個標(biāo)志,指示使用應(yīng)用程序應(yīng)使用默認(rèn)網(wǎng)格線顏色(取決于系統(tǒng))。覆蓋 colorId 中指定的任何顏色。
  • ShowFormulas是一個SheetViewOption。它指定一個標(biāo)志,指示此工作表是否應(yīng)顯示公式。
  • ShowGridLines是一個SheetViewOption。它指定一個標(biāo)志,指示此工作表是否應(yīng)顯示網(wǎng)格線。
  • ShowRowColHeaders是一個SheetViewOption。它指定一個標(biāo)志,指示工作表是否應(yīng)顯示行標(biāo)題和列標(biāo)題。
  • ShowZeros是一個SheetViewOption。它指定一個標(biāo)志,指示是否“在值為零的單元格中顯示零”。當(dāng)使用公式引用另一個空單元格時,當(dāng)標(biāo)志為 true 時,引用的值變?yōu)?0。默認(rèn)設(shè)置為 true。
  • RightToLeft是一個SheetViewOption。它指定一個標(biāo)志,指示工作表是否處于“從右到左”的顯示模式。在此模式下,列 A 位于最右側(cè),列 B ;位于列 A 的左側(cè)一列,依此類推。此外,單元格中的信息以從右到左的格式顯示。
  • ShowRuler是一個SheetViewOption。它指定一個標(biāo)志,指示此工作表應(yīng)顯示標(biāo)尺。
  • View是一個 SheetViewOption。它指定一個標(biāo)志,指示工作表的顯示方式,默認(rèn)情況下,它使用空字符串。
  • TopLeftCell是一個SheetViewOption。它指定左上角可見單元格的位置 右下窗格中左上角可見單元格的位置(從左到右模式時)。
  • ZoomScale是一個SheetViewOption。它為表示百分比值的當(dāng)前視圖指定窗口縮放放大倍率。此屬性限制為介于 10 到 400 之間的值。

以上就是Go-Excelize API源碼閱讀SetSheetViewOptions示例解析的詳細(xì)內(nèi)容,更多關(guān)于Go-Excelize API源碼閱讀的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • go嵌套匿名結(jié)構(gòu)體的初始化詳解

    go嵌套匿名結(jié)構(gòu)體的初始化詳解

    這篇文章主要介紹了go嵌套匿名結(jié)構(gòu)體的初始化詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • Golang高性能持久化解決方案BoltDB數(shù)據(jù)庫介紹

    Golang高性能持久化解決方案BoltDB數(shù)據(jù)庫介紹

    這篇文章主要為大家介紹了Golang高性能持久化解決方案BoltDB數(shù)據(jù)庫介紹,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2021-11-11
  • Golang對MongoDB數(shù)據(jù)庫的操作簡單封裝教程

    Golang對MongoDB數(shù)據(jù)庫的操作簡單封裝教程

    mongodb官方?jīng)]有關(guān)于go的mongodb的驅(qū)動,因此只能使用第三方驅(qū)動,mgo就是使用最多的一種。下面這篇文章主要給大家介紹了關(guān)于利用Golang對MongoDB數(shù)據(jù)庫的操作簡單封裝的相關(guān)資料,需要的朋友可以參考下
    2018-07-07
  • 淺談Golang的new與make區(qū)別是什么

    淺談Golang的new與make區(qū)別是什么

    本文主要介紹了Golang的new與make區(qū)別是什么,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • go程序部署到linux上運行的實現(xiàn)方法

    go程序部署到linux上運行的實現(xiàn)方法

    本文主要介紹了go程序部署到linux上運行的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • 如何在Golang中運行JavaScript

    如何在Golang中運行JavaScript

    最近寫一個程序,接口返回的數(shù)據(jù)是js格式的,需要通過golang來解析js,所以下面這篇文章主要給大家介紹了關(guān)于如何在Golang中運行JavaScript的相關(guān)資料,需要的朋友可以參考下
    2022-01-01
  • 基于Go語言實現(xiàn)冒泡排序算法

    基于Go語言實現(xiàn)冒泡排序算法

    冒泡排序是交換排序中最簡單的一種算法。這篇文章將利用Go語言實現(xiàn)冒泡排序算法,文中的示例代碼講解詳細(xì),對學(xué)習(xí)Go語言有一定的幫助,需要的可以參考一下
    2022-12-12
  • GoLang調(diào)用鏈可視化go-callvis使用介紹

    GoLang調(diào)用鏈可視化go-callvis使用介紹

    與鏈路追蹤(Tracing)不同,Tracing關(guān)注復(fù)雜的分布式環(huán)境中各個服務(wù)節(jié)點間的調(diào)用關(guān)系,主要用于服務(wù)治理。而我們本次探索的代碼調(diào)用鏈路則是代碼方法級別的調(diào)用關(guān)系,主要用于代碼設(shè)計
    2023-02-02
  • Golang Gorm 更新字段save、update、updates

    Golang Gorm 更新字段save、update、updates

    在gorm中,批量更新操作可以通過使用Update方法來實現(xiàn),本文主要介紹了Golang Gorm 更新字段save、update、updates,具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • go-zero源碼閱讀之布隆過濾器實現(xiàn)代碼

    go-zero源碼閱讀之布隆過濾器實現(xiàn)代碼

    布隆過濾器可以用于檢索一個元素是否在一個集合中。它的優(yōu)點是空間效率和查詢時間都比一般的算法要好的多,缺點是有一定的誤識別率和刪除困難,這篇文章主要介紹了go-zero源碼閱讀-布隆過濾器,需要的朋友可以參考下
    2023-02-02

最新評論