0

0

如何使用Go语言解析XML数据并提取Excel Worksheet中的数据?

心靈之曲

心靈之曲

发布时间:2024-11-07 18:33:52

|

1206人浏览过

|

来源于php中文网

原创

如何使用go语言解析xml数据并提取excel worksheet中的数据?

关于go读取xml中worksheet的问题

为了正确提取excel中worksheet结构内的数据,可以使用标准库encoding/xml进行解析。解析的具体步骤如下:

自由画布
自由画布

百度文库和百度网盘联合开发的AI创作工具类智能体

下载
  1. 定义与xml结构相对应的go结构体。
  2. 使用xml.unmarshal()函数将xml数据解析到结构体中。
  3. 遍历结构体中的字段来提取所需的数据。
package main

import (
    "encoding/xml"
    "fmt"
)

type Workbook struct {
    XMLName                xml.Name               `xml:"Workbook"`
    Text                   string                 `xml:",chardata"`
    Xmlns                  string                 `xml:"xmlns,attr"`
    O                      string                 `xml:"o,attr"`
    X                      string                 `xml:"x,attr"`
    Ss                     string                 `xml:"ss,attr"`
    Html                   string                 `xml:"html,attr"`
    DocumentProperties     DocumentProperties     `xml:"DocumentProperties"`
    OfficeDocumentSettings OfficeDocumentSettings `xml:"OfficeDocumentSettings"`
    ExcelWorkbook          ExcelWorkbook          `xml:"ExcelWorkbook"`
    Styles                 Styles                 `xml:"Styles"`
    Worksheet              Worksheet              `xml:"Worksheet"`
}

type DocumentProperties struct {
    Text   string `xml:",chardata"`
    Xmlns  string `xml:"xmlns,attr"`
    Author struct {
        Text string `xml:",chardata"`
    } `xml:"Author"`
    LastAuthor struct {
        Text string `xml:",chardata"`
    } `xml:"LastAuthor"`
    Created struct {
        Text string `xml:",chardata"`
    } `xml:"Created"`
    LastSaved struct {
        Text string `xml:",chardata"`
    } `xml:"LastSaved"`
    Version struct {
        Text string `xml:",chardata"`
    } `xml:"Version"`
}

type OfficeDocumentSettings struct {
    Text     string `xml:",chardata"`
    Xmlns    string `xml:"xmlns,attr"`
    AllowPNG struct {
        Text string `xml:",chardata"`
    } `xml:"AllowPNG"`
}

type ExcelWorkbook struct {
    Text         string `xml:",chardata"`
    Xmlns        string `xml:"xmlns,attr"`
    WindowHeight struct {
        Text string `xml:",chardata"`
    } `xml:"WindowHeight"`
    WindowWidth struct {
        Text string `xml:",chardata"`
    } `xml:"WindowWidth"`
    WindowTopX struct {
        Text string `xml:",chardata"`
    } `xml:"WindowTopX"`
    WindowTopY struct {
        Text string `xml:",chardata"`
    } `xml:"WindowTopY"`
    ProtectStructure struct {
        Text string `xml:",chardata"`
    } `xml:"ProtectStructure"`
    ProtectWindows struct {
        Text string `xml:",chardata"`
    } `xml:"ProtectWindows"`
}

type Styles struct {
    Text  string `xml:",chardata"`
    Style []struct {
        Text      string `xml:",chardata"`
        ID        string `xml:"ID,attr"`
        Name      string `xml:"Name,attr"`
        Parent    string `xml:"Parent,attr"`
        Alignment struct {
            Text       string `xml:",chardata"`
            Vertical   string `xml:"Vertical,attr"`
            Horizontal string `xml:"Horizontal,attr"`
        } `xml:"Alignment"`
        Borders struct {
            Text string `xml:",chardata"`
        } `xml:"Borders"`
        Font struct {
            Text     string `xml:",chardata"`
            FontName string `xml:"FontName,attr"`
            CharSet  string `xml:"CharSet,attr"`
            Size     string `xml:"Size,attr"`
            Color    string `xml:"Color,attr"`
        } `xml:"Font"`
        Interior struct {
            Text    string `xml:",chardata"`
            Color   string `xml:"Color,attr"`
            Pattern string `xml:"Pattern,attr"`
        } `xml:"Interior"`
        NumberFormat struct {
            Text   string `xml:",chardata"`
            Format string `xml:"Format,attr"`
        } `xml:"NumberFormat"`
        Protection struct {
            Text      string `xml:",chardata"`
            Protected string `xml:"Protected,attr"`
        } `xml:"Protection"`
    } `xml:"Style"`
}

type Worksheet struct {
    Text  string `xml:",chardata"`
    Name  string `xml:"Name,attr"`
    Table struct {
        Text                string `xml:",chardata"`
        ExpandedColumnCount string `xml:"ExpandedColumnCount,attr"`
        ExpandedRowCount    string `xml:"ExpandedRowCount,attr"`
        FullColumns         string `xml:"FullColumns,attr"`
        FullRows            string `xml:"FullRows,attr"`
        DefaultColumnWidth  string `xml:"DefaultColumnWidth,attr"`
        DefaultRowHeight    string `xml:"DefaultRowHeight,attr"`
        Column              []struct {
            Text    string `xml:",chardata"`
            StyleID string `xml:"StyleID,attr"`
            Width   string `xml:"Width,attr"`
            Span    string `xml:"Span,attr"`
            Index   string `xml:"Index,attr"`
        } `xml:"Column"`
        Row []struct {
            Text          string `xml:",chardata"`
            AutoFitHeight string `xml:"AutoFitHeight,attr"`
            StyleID       string `xml:"StyleID,attr"`
            Cell          []struct {
                Text    string `xml:",chardata"`
                StyleID string `xml:"StyleID,attr"`
                Data    struct {
                    Text string `xml:",chardata"`
                    Type string `xml:"Type,attr"`
                } `xml:"Data"`
            } `xml:"Cell"`
        } `xml:"Row"`
    } `xml:"Table"`
    WorksheetOptions struct {
        Text      string `xml:",chardata"`
        Xmlns     string `xml:"xmlns,attr"`
        PageSetup struct {
            Text   string `xml:",chardata"`
            Header struct {
                Text   string `xml:",chardata"`
                Margin string `xml:"Margin,attr"`
            } `xml:"Header"`
            Footer struct {
                Text   string `xml:",chardata"`
                Margin string `xml:"Margin,attr"`
            } `xml:"Footer"`
            PageMargins struct {
                Text   string `xml:",chardata"`
                Bottom string `xml:"Bottom,attr"`
                Left   string `xml:"Left,attr"`
                Right  string `xml:"Right,attr"`
                Top    string `xml:"Top,attr"`
            } `xml:"PageMargins"`
        } `xml:"PageSetup"`
        Unsynced struct {
            Text string `xml:",chardata"`
        } `xml:"Unsynced"`
        Print struct {
            Text             string `xml:",chardata"`
            ValidPrinterInfo struct {
                Text string `xml:",chardata"`
            } `xml:"ValidPrinterInfo"`
            PaperSizeIndex struct {
                Text string `xml:",chardata"`
            } `xml:"PaperSizeIndex"`
            HorizontalResolution struct {
                Text string `xml:",chardata"`
            } `xml:"HorizontalResolution"`
            VerticalResolution struct {
                Text string `xml:",chardata"`
            } `xml:"VerticalResolution"`
        } `xml:"Print"`
        Selected struct {
            Text string `xml:",chardata"`
        } `xml:"Selected"`
        Panes struct {
            Text string `xml:",chardata"`
            Pane struct {
                Text   string `xml:",chardata"`
                Number struct {
                    Text string `xml:",chardata"`
                } `xml:"Number"`
                ActiveRow struct {
                    Text string `xml:",chardata"`
                } `xml:"ActiveRow"`
                ActiveCol struct {
                    Text string `xml:",chardata"`
                } `xml:"ActiveCol"`
            } `xml:"Pane"`
        } `xml:"Panes"`
        ProtectObjects struct {
            Text string `xml:",chardata"`
        } `xml:"ProtectObjects"`
        ProtectScenarios struct {
            Text string `xml:",chardata"`
        } `xml:"ProtectScenarios"`
    } `xml:"WorksheetOptions"`
}

func main() {
    var book Workbook
    err := xml.Unmarshal([]byte(xmldata), &book)
    if err != nil {
        fmt.Println(err)
        return
    }
    fmt.Println(book.Worksheet.Table.Row)
}

var xmldata = `
 

					

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1905

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2094

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1089

2024.11.28

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

282

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

192

2025.07.04

Go中Type关键字的用法
Go中Type关键字的用法

Go中Type关键字的用法有定义新的类型别名或者创建新的结构体类型。本专题为大家提供Go相关的文章、下载、课程内容,供大家免费下载体验。

234

2023.09.06

go怎么实现链表
go怎么实现链表

go通过定义一个节点结构体、定义一个链表结构体、定义一些方法来操作链表、实现一个方法来删除链表中的一个节点和实现一个方法来打印链表中的所有节点的方法实现链表。

450

2023.09.25

go语言编程软件有哪些
go语言编程软件有哪些

go语言编程软件有Go编译器、Go开发环境、Go包管理器、Go测试框架、Go文档生成器、Go代码质量工具和Go性能分析工具等。本专题为大家提供go语言相关的文章、下载、课程内容,供大家免费下载体验。

255

2023.10.13

AO3官网入口与中文阅读设置 AO3网页版使用与访问
AO3官网入口与中文阅读设置 AO3网页版使用与访问

本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

45

2026.02.02

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 8.3万人学习

Excel 教程
Excel 教程

共162课时 | 15.1万人学习

PHP基础入门课程
PHP基础入门课程

共33课时 | 2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号