当我们想要在不同的程序、系统或平台之间共享信息时,就需要一种统一的方式来组织和表示数据。XML(EXtensible Markup Language,即可扩展标记语言)是一种用于描述数据的标记语言,它让数据以一种结构化的方式呈现,使得计算机程序能够轻松理解和处理这些数据。
XML有以下特点:
常见的XML解析方式有以下几种:
TinyXML-2 是一个简单、小型、高效的 C++ XML 解析器,可被轻易地集成到其他程序中。它使用文档对象模型(DOM)的方式解析XML,可使用它解析 XML 文档,并读取、修改和保存的文档对象模型。
使用TinyXML-2可以实现对XML文件的:创建、解析、修改等功能。
该项目的GitHub链接如下:
TinyXML-2 【github项目】
也可以从此处下载TinyXML2源码(免费,不需要积分):
【免费】XML解析工具-TinyXML2-源代码-C++资源-CSDN文库
创建testXML.xml,内容如下所示:
null
windows7 c
windows7 c++
windows7 java
windows7 python
windows10 c
windows10 c++
windows10 java
windows10 python
windows11 c
windows11 c++
windows11 java
windows11 python
ubuntu_c
ubuntu_c++
ubuntu_java
ubuntu_python
centos_c
centos_c++
centos_java
centos_python
注:
- 根元素为 system ,其中包含 android、windows、linux三个操作系统大类。
- 每个操作系统大类下又包含具体的操作系统版本,如windows包含windows7、windows10、windows11等。
- 对每一个具体的操作系统版本,包含了用以存储若干app的 apps 。
- 每个应用存储到具体的某个app中。
将TinyXML-2项目中的 tinyxml2.cpp、tinyxml2.h 两个文件拷贝到当前的工作目录。
本次以 读取并输出 “某类操作系统” 中的 “各个具体操作系统版本” 的 “app内容” 为例:
创建readxml.cpp并编辑,该文件内容如下:
#include
#include
#include "tinyxml2.h"
using namespace tinyxml2;
using namespace std;
//定义结构体OS_APPS以进行数据存储
typedef struct os_apps{
string osname;
vector apps;
} OS_APPS;
//输出容器中的所有信息
void show(vector &v)
{
cout<<"\n----------print----------" << endl;
for(OS_APPS oa : v)
{
cout << "osname: " << oa.osname << endl;
int cnt = 1;
for(auto app : oa.apps)
{
cout << "app" << cnt << ": " << app << endl;
cnt ++;
}
cout << endl;
}
}
//从XMLDocument中读取指定的操作系统大类,并存储到容器中
void read_xml(XMLDocument* doc, vector &v, const char* target_os)
{
// 获取根元素
XMLElement* root = doc->RootElement();
if (!root) {
std::cout << "No root element found!" << std::endl;
exit(1);
}
// 查找指定OS类别
XMLElement* os_element = root->FirstChildElement(target_os);
if (!os_element)
{
// 未找到指定元素
cout << "os_element not found!" << endl;
exit(1);
}
// 遍历所有指定分类下的所有子OS
XMLElement* sub_os_element = os_element -> FirstChildElement();
if(!sub_os_element)
{
cout << "can't get sub_os_element!" << endl;
exit(1);
}
while(sub_os_element)
{
OS_APPS oa;
vector s;
//获取子操作系统的名称
oa.osname = sub_os_element -> Value();
//获取存储apps列表的节点
XMLElement* apps_element = sub_os_element -> FirstChildElement();
if(!apps_element)
{
cout << "can't read " << oa.osname << "'apps, please check XML file!" << endl;
exit(1);
}
else
{
cout << "begin to read " << oa.osname << "'s apps" << endl;
}
//获取每一个app元素,并继续读取其他同级app内容
XMLElement* app_element = apps_element -> FirstChildElement();
while(app_element)
{
s.push_back(app_element -> GetText());
app_element = app_element -> NextSiblingElement();
}
//存储
oa.apps = s;
v.push_back(oa);
//继续处理同级的其他子OS
sub_os_element = sub_os_element -> NextSiblingElement();
}
}
int main( int argc, const char ** argv)
{
//读取的数据将存放在容器v中
vector v;
//参数校验
if(argc == 1)
{
cout << "please input the XML filename!" << endl;
exit(0);
}
//打开文件
XMLDocument* doc = new XMLDocument();
doc->LoadFile( argv[1] );
if (doc->ErrorID() != XML_SUCCESS)
{
cout << "Error loading XML file!" << endl;
return 1;
}
printf( "XML file '%s' is loaded.\n", argv[1]);
//读取指定类别信息,并存储到容器v中
read_xml(doc, v, "windows");
//输出读取的信息
show(v);
return 0;
}
在命令行执行以下命令:
g++ -g -c tinyxml2.cpp -o tinyxml2.o
g++ -g -c readxml.cpp -o readxml.o
g++ -g -o read_xml_test tinyxml2.o readxml.o
执行程序:
./read_xml_test testXML.xml
执行结果如下所示:
可以看到,XML中的文件已经被成功读取。
这里是以上测试代码文件(为了方便测试,补充了makefile文件和shell脚本)。
run_test.sh shell文件,清理当前目录,重新执行make命令,并运行代码
Makefile makefile文件,编译并链接项目
readxml.cpp XML解析测试源文件
tinyxml2.cpp TinyXML-2 源文件
tinyxml2.h TinyXML-2头文件testXML.xml 测试用xml文件
执行结果如下:
下载链接:
【免费】XML解析示例项目-读取并输出xml的指定内容示例资源-CSDN文库
在tinyxml2.h 中,给出了函数的定义,功能及参数类型,可根据需求寻找与使用相应的函数。
如有不当或错误之处,恳请您的指正,谢谢!!!