C++ XML解析之TinyXML篇

简介: 最近使用TinyXML进行C++ XML解析,感觉使用起来比较简单,很容易上手,本文给出一个使用TinyXML进行XML解析的简单例子,很多复杂的应用都可以基于本例子的方法来完成。以后的文章里会讲解使用Xerces进行C++ XML解析的例子,希望大家一起交流。
最近使用TinyXML进行C++ XML解析,感觉使用起来比较简单,很容易上手,本文给出一个使用TinyXML进行XML解析的简单例子,很多复杂的应用都可以基于本例子的方法来完成。以后的文章里会讲解使用Xerces进行C++ XML解析的例子,希望大家一起交流。

    TinyXML是一个开源的解析XML的解析库,能够用于C++,能够在Windows或Linux中编译。这个解析库的模型通过解析XML文件,然后在内存中生成DOM模型,从而让我们很方便的遍历这棵XML树。

    DOM模型即文档对象模型,是将整个文档分成多个元素(如书、章、节、段等),并利用树型结构表示这些元素之间的顺序关系以及嵌套包含关系。

    首先从网上下载TinyXML的库,文件夹的名字是TinyXpath,在工程里做如下配置:

    在附加包含路径里添加:你的tinyxpath路径/tinyxpath/include

    在附加库路径里添加:你的tinyxpath路径/tinyxpath/lib

    在对象/库路径里添加:tinyxpathd.lib,如果使用release版本,则是tinyxpath.lib。

    另外,由于我开发的项目是多线程的,所以设置了多线程的环境,因此使用TinyXML没有出现问题。本人将TinyXML写在一个单独的C++工程进行测试,发现如果不设置多线程的环境,会出现链接错误。我觉得原因可能是TinyXML使用了多线程环境,因此需要设置多线程的环境。在工程/设置下的C/C++选项卡中,选择Code Generation,在Use run-time library中选择Debug MultiThreaed DLL即可。

    本例的XML文件Students.xml如下:

    <Class name="计算机软件班">

    <Students>

    <student name="张三" studentNo="13031001" sex="男" age="22">

    <phone>88208888</phone>

    <address>西安市太白南路二号</address>

    </student>

    <student name="李四" studentNo="13031002" sex="男" age="20">

    <phone>88206666</phone>

    <address>西安市光华路</address>

    </student>

    </Students>

    </Class>

    程序代码XmlParseExample.cpp如下所示:

        程序运行结果如下:

#include <iostream>

    #include <string>

    #include <tinyxml.h>

    using std::string;

    int main()

    {

    TiXmlDocument* myDocument = new TiXmlDocument();

    myDocument->LoadFile("Students.xml");

    TiXmlElement* rootElement = myDocument->RootElement();  //Class

    TiXmlElement* studentsElement = rootElement->FirstChildElement();  //Students

    TiXmlElement* studentElement = studentsElement->FirstChildElement();  //Students

    while ( studentElement ) {

    TiXmlAttribute* attributeOfStudent = studentElement->FirstAttribute();  //获得student的name属性

    while ( attributeOfStudent ) {

    std::cout 《 attributeOfStudent->Name() 《 " : " 《 attributeOfStudent->Value() 《 std::endl;

    attributeOfStudent = attributeOfStudent->Next();

    }

    TiXmlElement* phoneElement = studentElement->FirstChildElement();//获得student的phone元素

    std::cout 《 "phone" 《 " : " 《 phoneElement->GetText() 《 std::endl;

    TiXmlElement* addressElement = phoneElement->NextSiblingElement();

    std::cout 《 "address" 《 " : " 《 phoneElement->GetText() 《 std::endl;

    studentElement = studentElement->NextSiblingElement();

    }

    return 0;

    }

    name : 张三

    studentNo : 13031001

    sex : 男

    age : 22

    phone : 88208888

    address : 88208888

    name : 李四

    studentNo : 13031002

    sex : 男

    age : 20

    phone : 88206666

    address : 88206666

本例中使用的是对xml文件进行解析,很容易掌握,但是很多开发人员不知道如何对xml 字符流(非xml文件)进行解析,我看了TinyXML提供的源代码,里面可以使用如下方法对xml流解析。对应于上例,代码如下:

    string xmlString =

    "<Class name=\"计算机软件班\">\

    <Students>\

    <student name=\"张三\" studentNo=\"13031001\" sex=\"男\" age=\"22\">\

    <phone>88208888</phone>\

    <address>西安市太白南路二号</address>\

    </student>\

    <student name=\"李四\" studentNo=\"13031002\" sex=\"男\" age=\"20\">\

    <phone>88206666</phone>\

    <address>西安市光华路</address>\

    </student>\

    </Students>\

    </Class>";

    TiXmlDocument* myDocument = new TiXmlDocument();

    myDocument->Parse(xmlString.c_str());

    使用Parse函数就可以解析XML字符流了,这是很多开发者不太熟悉的情况。

    如果开发者开发特定应用,就可以使用上述类似方法,可能不需要完全处理每一个属性,比如可以对属性名进行判断,只处理自己需要的属性,或者自己需要的xml元素。还可以使用TinyXML的方法创建xml元素和xml属性,或者设置xml元素和属性对应的值,等等,如果读者想要类似的例子,可以留言写出。

    下面介绍TinyXML的一些类。在TinyXML中,根据XML的各种元素来定义了一些类:

    TiXmlBase:整个TinyXML模型的基类。

    TiXmlAttribute:对应于XML中的元素的属性。

    TiXmlNode:对应于DOM结构中的节点。

    TiXmlComment:对应于XML中的注释

    TiXmlDeclaration:对应于XML中的申明部分,<?versiong="1.0" ?>。

    TiXmlDocument:对应于XML的整个文档。

    TiXmlElement:对应于XML的元素。

    TiXmlText:对应于XML的文字部分

    TiXmlUnknown:对应于XML的未知部分。

    TiXmlHandler:定义了针对XML的一些操作。

相关文章
|
对象存储
基于RuoYi-Flowable-Plus的若依ruoyi-nbcio支持本地图片上传与回显的功能实现(二)
基于RuoYi-Flowable-Plus的若依ruoyi-nbcio支持本地图片上传与回显的功能实现(二)
363 0
|
关系型数据库 MySQL Java
实时计算 Flink版操作报错之遇到java.lang.IllegalStateException: The elasticsearch emitter must be serializable.的错误,如何处理
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
存储 IDE Java
如何检查类文件是否被篡改?
类文件被篡改可能导致安全问题和程序异常。检查方法包括:1. 比对文件哈希值;2. 使用反编译工具对比代码;3. 检查文件签名。确保类文件的完整性和安全性。
295 3
|
数据采集 存储 人工智能
AI 模型:数据收集和清洗
AI 模型:数据收集和清洗
1263 2
|
编解码 Shell Linux
【Shell 命令集合 系统设置 】Linux 调整终端窗口的大小 resize命令 使用指南
【Shell 命令集合 系统设置 】Linux 调整终端窗口的大小 resize命令 使用指南
616 0
|
Linux C语言 开发者
Linux嵌入式系统之交叉编译中构建交叉编译工具链
Linux嵌入式系统之交叉编译中构建交叉编译工具链
511 0
|
Shell Linux 测试技术
Android App性能评测分析-cpu占用篇
1、前言 很多时候在使用APP的时候,手机可能会发热发烫。这是因为CPU使用率过高,CPU过于繁忙,会使整个手机无法响应用户,整体性能降低,用户体验就会很差,也容易引起ANR等等一系列问题。
5732 0
|
算法 定位技术
浅谈P、NP、NP-Complate和NP-Hard问题
时间复杂度 时间复杂度并不是表示一个程序解决问题需要花多少时间,而是当程序所处理的问题规模扩大后,程序需要的时间长度对应增长得有多快。 也就是说,对于某一个程序,其处理某一个特定数据的效率不能衡量该程序的好坏,而应该看当这个数据的规模变大到数百倍后,程序运行时间是否还是一样,或者也跟着慢了数百倍,或者变慢了数万倍。 不管数据有多大,程序处理所花的时间始终是那么多的,我们就说这个程序很好,具O(1)O(1)O(1)的时间复杂度,也称常数级复杂度;
|
机器学习/深度学习 存储 数据可视化
PyTorch 神经网络模型可视化(Netron)
PyTorch 神经网络模型可视化(Netron)
3243 0