一個自己實現的Excel as relate db讀取庫go-excel
在複雜的系統中(例如遊戲),有時候為了便於非專業人員(策劃)設定一些配置,會使用Excel作為一種輕量級的關聯式資料庫或者配置檔案,畢竟對於很多非開發人員來說,配個Excel要比寫json或者yaml什麼簡單得多。
而且Excel可以寫入各種格式和字型標紅單元格,維護成本大大降低。
這種場景下,讀取特定格式(符合關聯式資料庫特點的表格)的資料會比各種花式寫入Excel的功能更重要,畢竟從編輯上來說微軟提供的Excel本身功能就非常強大了,而現在我找到的Excel庫的功能都過於強大了,用起來有點浪費,於是寫了這個簡化庫。
這個庫的工作參考了tealeg/xlsx的部分實現和讀取邏輯。
假設有一個xlsx檔案,裡邊有個Sheet叫“Standard”,它的資料結構如下:
ID | NameOf | Age | Slice | UnmarshalString |
---|---|---|---|---|
1 | Andy | 1 | 1|2 | {"Foo":"Andy"} |
2 | Leo | 2 | 2|3|4 | {"Foo":"Leo"} |
3 | Ben | 3 | 3|4|5|6 | {"Foo":"Ben"} |
4 | Ming | 4 | 1 | {"Foo":"Ming"} |
- 第0行是標題行。
- 第1行開始是資料行。
以下是最簡單的寫法
// defined a struct
type Standard struct {
// use field name as default column name
ID int
// column means to map the column name
Name string `xlsx:"column(NameOf)"`
// you can map a column into more than one field
NamePtr *string `xlsx:"column(NameOf)"`
// omit `column` if only want to map to column name, it's equal to `column(AgeOf)`
Age int `xlsx:"AgeOf"`
// split means to split the string into slice by the `|`
Slice []int `xlsx:"split(|)"`
// *Temp implement the `encoding.BinaryUnmarshaler`
Temp *Temp `xlsx:"column(UnmarshalString)"`
// use '-' to ignore.
Ignored string `xlsx:"-"`
}
// func (this Standard) GetXLSXSheetName() string {
// return "Some other sheet name if need"
// }
type Temp struct {
Foo string
}
// self define a unmarshal interface to unmarshal string.
func (this *Temp) UnmarshalBinary(d []byte) error {
return json.Unmarshal(d, this)
}
func main() {
// will assume the sheet name as "Standard" from the struct name.
var stdList []Standard
err := excel.UnmarshalXLSX("./testdata/simple.xlsx", &stdList)
if err != nil {
panic(err)
}
}
提供一些更復雜的讀取邏輯,詳細看文件:https://github.com/szyhf/go-excel
時間關係,可能看test目錄裡的程式碼更好理解……
歡迎捉蟲提bug。
相關文章
- 實現一個自己的mvvmMVVM
- 自己實現一個java的arraylistJava
- 如何自己實現一個簡單的webpack構建工具 【精讀】Web
- Python筆記一之excel的讀取Python筆記Excel
- python對Excel的讀取PythonExcel
- 使用openpyxl庫讀取Excel檔案資料Excel
- eazyexcel 讀取excel資料插入資料庫Excel資料庫
- 實現一個屬於自己的React框架(一)React框架
- Laravel讀取ExcelLaravelExcel
- 200 行程式碼實現一個高效快取庫行程快取
- 透過 adc 實現一個IO對多個按鍵讀取
- 自己實現一個window.location
- [提問交流]讀取資料庫中的配置 這個 DB_CONFIG_DATA 是什麼?資料庫
- EasyExcel庫來讀取指定Excel檔案中的資料Excel
- Python讀取Excel表格PythonExcel
- python中xlrd庫如何實現檔案讀取?Python
- 自己動手實現一個簡單的 IOC
- 自己用 Netty 實現一個簡單的 RPCNettyRPC
- python中的一個現象,db.commit和db.commit()PythonMIT
- 自己動手實現一個前端路由前端路由
- 自己實現一個滑動視窗
- 自己動手實現一個EventBus框架框架
- 自己實現一個Controller——終極型Controller
- 自己實現一個Controller——精簡型Controller
- 封裝一個自己的js庫封裝JS
- 用 (Excel) VBA 讀取 OneNote!Excel
- 前端讀取excel檔案前端Excel
- 如何自己實現一個 mobx – 原理解析
- 自己動手實現一個阻塞佇列佇列
- SpringBoot讀取yml的一個bugSpring Boot
- 自己實現一個 DFA 串模式識別器(一)模式
- 從零開始 實現一個自己的指令碼引擎指令碼
- 從零開始實現一個自己的指令碼引擎指令碼
- Maatwebsite\Excel 讀取帶公式的excel檔案得到值呢?WebExcel公式
- ABAP--一個讀取EXCEL單元格的內容超過256個字元的程式碼樣例Excel字元
- 自己實現一個SAP WebClient UI Repository Information SystemWebclientUIORM
- 自己實現一個Electron跨程式訊息元件元件
- 讀取和儲存Excel表Excel
- POI 分批讀取Excel資料Excel