Go-Excelize API源码阅读(一)——NewFile()

简介: 开源摘星计划(WeOpen Star) 是由腾源会 2022 年推出的全新项目,旨在为开源人提供成长激励,为开源项目提供成长支持,助力开发者更好地了解开源,更快地跨越鸿沟,参与到开源的具体贡献与实践中。不管你是开源萌新,还是希望更深度参与开源贡献的老兵,跟随“开源摘星计划”开启你的开源之旅,从一篇学习笔记、到一段代码的提交,不断挖掘自己的潜能,最终成长为开源社区的“闪亮之星”。

### Go-Excelize API源码阅读(一)——NewFile()

开源摘星计划(WeOpen Star) 是由腾源会 2022 年推出的全新项目,旨在为开源人提供成长激励,为开源项目提供成长支持,助力开发者更好地了解开源,更快地跨越鸿沟,参与到开源的具体贡献与实践中。


不管你是开源萌新,还是希望更深度参与开源贡献的老兵,跟随“开源摘星计划”开启你的开源之旅,从一篇学习笔记、到一段代码的提交,不断挖掘自己的潜能,最终成长为开源社区的“闪亮之星”。


我们将同你一起,探索更多的可能性!


项目地址: WeOpen-Star:https://github.com/weopenprojects/WeOpen-Star

#### 一、Go-Excelize简介

Excelize 是 Go 语言编写的用于操作 Office Excel 文档基础库,基于 ECMA-376,ISO/IEC 29500 国际标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的电子表格文档。支持 XLAM / XLSM / XLSX / XLTM / XLTX 等多种文档格式,高度兼容带有样式、图片(表)、透视表、切片器等复杂组件的文档,并提供流式读写 API,用于处理包含大规模数据的工作簿。可应用于各类报表平台、云计算、边缘计算等系统。使用本类库要求使用的 Go 语言为 1.15 或更高版本。


#### 二、NewFile()

该API的功能是利用默认的模板创建新的 Excel 工作薄,新创建的工作簿中会默认包含一个名为 Sheet1 的工作表。


```

func NewFile() *File {

f := newFile()

f.Pkg.Store("_rels/.rels", []byte(xml.Header+templateRels))

f.Pkg.Store(defaultXMLPathDocPropsApp, []byte(xml.Header+templateDocpropsApp))

f.Pkg.Store(defaultXMLPathDocPropsCore, []byte(xml.Header+templateDocpropsCore))

f.Pkg.Store("xl/_rels/workbook.xml.rels", []byte(xml.Header+templateWorkbookRels))

f.Pkg.Store("xl/theme/theme1.xml", []byte(xml.Header+templateTheme))

f.Pkg.Store("xl/worksheets/sheet1.xml", []byte(xml.Header+templateSheet))

f.Pkg.Store(defaultXMLPathStyles, []byte(xml.Header+templateStyles))

f.Pkg.Store(defaultXMLPathWorkbook, []byte(xml.Header+templateWorkbook))

f.Pkg.Store(defaultXMLPathContentTypes, []byte(xml.Header+templateContentTypes))

f.SheetCount = 1

f.CalcChain = f.calcChainReader()

f.Comments = make(map[string]*xlsxComments)

f.ContentTypes = f.contentTypesReader()

f.Drawings = sync.Map{}

f.Styles = f.stylesReader()

f.DecodeVMLDrawing = make(map[string]*decodeVmlDrawing)

f.VMLDrawing = make(map[string]*vmlDrawing)

f.WorkBook = f.workbookReader()

f.Relationships = sync.Map{}

f.Relationships.Store("xl/_rels/workbook.xml.rels", f.relsReader("xl/_rels/workbook.xml.rels"))

f.sheetMap["Sheet1"] = "xl/worksheets/sheet1.xml"

ws, _ := f.workSheetReader("Sheet1")

f.Sheet.Store("xl/worksheets/sheet1.xml", ws)

f.Theme = f.themeReader()

return f

}

```

`f.Pkg`是`file`结构体的一个成员,定义要填充的电子表格文件结构。

```

type File struct {

...省略其他...

Pkg              sync.Map

}

```

`func (m *Map) Store(key, value any)`是将值存入`Map`之中。


接下来,SheetCount是表格的数量。默认是一个Sheet1,所以初始数量是1.


CalcChain是有calcChainReader()计算的,该函数解析defaultXMLPathCalcChain配置中的文件生成一个xlsxCalcChain类型的数据,程序中读取的文件地址是xl/calcChain.xml。xlsxCalcChain直接映射calcChain元素。这个元素代表了计算链的根。


Comments新建一个`map[string]*xlsxComments`。


ContentTypes由contentTypesReader创建,contentTypesReader提供了一个函数来获取反序列化后的[Content_Types].xml文件结构的指针。


`f.Relationships`和`f.Drawings = sync.Map{}`是创建一个并发状况下的Map。


同样的,`Styles`由f.stylesReader()创建,提供了一个函数来获取反序列化后的`xl/styles.xml`文件结构的指针。f.WorkBook也差不多。


VMLDrawing 、DecodeVMLDrawing都是创建map。




接下来是sheet1的相关创建操作。


#### 三、结语

这里是老岳,这是Go语言相关源码的解读第一篇,我会不断努力,给大家带来更多类似的文章,恳请大家不吝赐教。




目录
相关文章
|
1月前
|
缓存 前端开发 中间件
[go 面试] 前端请求到后端API的中间件流程解析
[go 面试] 前端请求到后端API的中间件流程解析
|
16天前
|
缓存 弹性计算 API
用 Go 快速开发一个 RESTful API 服务
用 Go 快速开发一个 RESTful API 服务
|
16天前
|
存储 算法 Java
Go 通过 Map/Filter/ForEach 等流式 API 高效处理数据
Go 通过 Map/Filter/ForEach 等流式 API 高效处理数据
|
24天前
|
存储 Linux API
Linux源码阅读笔记08-进程调度API系统调用案例分析
Linux源码阅读笔记08-进程调度API系统调用案例分析
|
24天前
|
Linux API
Linux源码阅读笔记07-进程管理4大常用API函数
Linux源码阅读笔记07-进程管理4大常用API函数
|
30天前
|
JSON 算法 API
京东以图搜图功能API接口调用算法源码python
京东图搜接口是一款强大工具,通过上传图片即可搜索京东平台上的商品。适合电商平台、比价应用及需商品识别服务的场景。使用前需了解接口功能并注册开发者账号获取Key和Secret;准备好图片的Base64编码和AppKey;生成安全签名后,利用HTTP客户端发送POST请求至接口URL;最后解析JSON响应数据以获取商品信息。
|
1月前
|
Go API
Go - 统一定义 API 错误码
Go - 统一定义 API 错误码
40 9
|
1月前
|
测试技术 编译器 Go
依赖注入与控制反转:优化Go语言REST API客户端
依赖注入与控制反转:优化Go语言REST API客户端
|
16天前
|
消息中间件 缓存 API
go-zero微服务实战系列(三、API定义和表结构设计)
go-zero微服务实战系列(三、API定义和表结构设计)
|
17天前
|
JSON API 网络架构
Django 后端架构开发:DRF 高可用API设计与核心源码剖析
Django 后端架构开发:DRF 高可用API设计与核心源码剖析
32 0