在 Go 中将 Excel 文件数据转换为 JSON 字符串,无需任何结构体定义
短信预约 -IT技能 免费直播动态提醒
问题内容
我是 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 字符串,无需任何结构体定义的详细内容,更多请关注编程网其它相关文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
在 Go 中将 Excel 文件数据转换为 JSON 字符串,无需任何结构体定义
下载Word文档到电脑,方便收藏和打印~
下载Word文档
猜你喜欢
在 Go 中将 Excel 文件数据转换为 JSON 字符串,无需任何结构体定义
问题内容我是 go 语言新手。我有一个要求,应用程序将读取 excel 文件并将其转换为 json 字符串,而不依赖于任何定义的结构。我探索了一些库,其中要么需要此结构定义,要么至少必须有 excel 列标题。例如,github.com
2024-02-06