我是 go 語言新手。我有一個要求,應用程式將讀取 excel 檔案並將其轉換為 json 字串,而不依賴任何定義的結構。我探索了一些庫,其中要么需要此結構定義,要么至少必須有 excel 列標題。例如,
github.com/xuri/excelize github.com/onkarvhanumante/Excel2JsonTree github.com/FerdinaKusumah/excel2json
但是,我找不到任何可以處理原始 excel 資料並將其轉換為 json 的地方。
請指導一下,謝謝!
如果可以將所有值都視為字串,那麼您可以按照下面的程式碼片段所示進行操作。該腳本讀取所有工作表(選項卡)並建立兩種格式的 json 檔案(帶標題和不帶標題)。
package main import ( "encoding/json" "fmt" "os" "github.com/xuri/excelize/v2" ) func main() { f, err := excelize.OpenFile("test.xlsx") if err != nil { fmt.Println(err) return } defer func() { if err := f.Close(); err != nil { fmt.Println(err) } }() // could have multiple sheets sheets := f.GetSheetList() for _, sheetName := range sheets { d, err := f.GetRows(sheetName) if err != nil { fmt.Println("error reading sheet", sheetName, ":", err) return } saveAsJSON(d, sheetName+".json") saveAsJSONWithHeaders(d, sheetName+"_with_headers.json") } } func saveAsJSONWithHeaders(rows [][]string, filename string) error { data := make([]map[string]string, len(rows)-1) headers := rows[0] // excluding header row for i, row := range rows[1:] { data[i] = make(map[string]string) for j, cellValue := range row { data[i][headers[j]] = cellValue } } return saveAsJSON(data, filename) } func saveAsJSON(data interface{}, filename string) error { file, err := os.Create(filename) if err != nil { return err } defer file.Close() encoder := json.NewEncoder(file) if err := encoder.Encode(data); err != nil { return err } return nil }
以上是在 Go 中將 Excel 檔案資料轉換為 JSON 字串,無需任何結構體定義的詳細內容。更多資訊請關注PHP中文網其他相關文章!