首頁 >後端開發 >Golang >在 Go 中將 Excel 檔案資料轉換為 JSON 字串,無需任何結構體定義

在 Go 中將 Excel 檔案資料轉換為 JSON 字串,無需任何結構體定義

WBOY
WBOY轉載
2024-02-05 22:45:08557瀏覽

在 Go 中将 Excel 文件数据转换为 JSON 字符串,无需任何结构体定义

問題內容

我是 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中文網其他相關文章!

陳述:
本文轉載於:stackoverflow.com。如有侵權,請聯絡admin@php.cn刪除