发布时间:2023-02-23 11:30
利用DOM相关类读取xml文件。
Dom(Document Object Model,即文档对象模型)把XML文档转换成应用程序可以遍历的树形结构,这样便可以随机访问其中的节点。它的缺点是需要将整个XML文档读入内存,消耗内存较多。
在Qt中使用QDomProcessingInstruction类来表示XML说明,元素对应QDomElement类,属性对应QDomAttr类,文本内容由QDomText类表示。所有的DOM节点,比如这里的说明、元素、属性和文本等,都使用QDomNode类来表示,然后使用对应的isProcessingInstruction()、isElement()、isAttr()和isText()等函数来判断是否是该类型的元素,如果是,那么就可以使用toProcessingInstruction()、toElement()、toAttr()和toText()等函数转换为具体的节点类型。
新建一个Qt案例,项目名称为“DomTest”,基类选择“QWidget”,取消创建UI界面复选框的选中状态,完成项目创建。
无UI界面
新建一个xml文件,内容为:
<archive>
<car id=\"1\">
<attrib number=\"01\" >排量:2393mlattrib>
<attrib number=\"02\" >价格:43.26万元attrib>
car>
<car id=\"2\" >
<attrib number=\"01\" >排量:1600mlattrib>
<attrib number=\"02\" >价格:8.98万元attrib>
car>
<car id=\"3\" >
<attrib number=\"01\" >排量:1600mlattrib>
<attrib number=\"02\" >价格:11.25万元attrib>
car>
<car id=\"4\" >
<attrib number=\"01\" >排量:1997mlattrib>
<attrib number=\"02\" >价格:15.38万元attrib>
car>
archive>
在DomTest.pro文件中添加如下代码:
QT+=xml
核心代码如下:
//新建QDomDocument类对象,它代表一个XML文档
QDomDocument doc;
//建立指向“node.xml”文件的QFile对象
QFile file(\"node.xml\");
//以只读方式打开
if(!file.open(QIODevice::ReadOnly))
{
qDebug()<<\"无法打开\";
return 0;
}
//将文件内容读到doc中
QString errorMsg;
if(!doc.setContent(&file,&errorMsg))
{
qDebug()<<errorMsg;//如果读取出错则返回错误类型
file.close();
return 0;
}
//关闭文件
file.close();
//获得doc的第一个节点,即XML说明
QDomNode firstNode=doc.firstChild();
//输出XML说明
qDebug()<<firstNode.nodeName();
qDebug()<<firstNode.nodeValue();
运行结果:
“xml”
“version=‘1.0’ encoding=‘UTF-8’”
如果不希望看到引号,可以进行如下修改:
qDebug() << qPrintable(firstNode.nodeName());
qDebug()<< qPrintable(firstNode.nodeValue());
运行结果:
xml
version=‘1.0’ encoding=‘UTF-8’
查找id节点及其对应的名称:
//如果节点不为空
while(!n.isNull())
{
if(n.isElement()) //如果节点是元素
{
QDomElement e=n.toElement();//将其转换为元素
qDebug()<<e.tagName();//返回元素标记
qDebug()<<e.attribute(\"id\");//返回元素id属性的值
}
n=n.nextSibling(); //下一个兄弟节点
}
运行结果:
“car”
“1”
“car”
“2”
“car”
“3”
“car”
“4”
输出所有子节点的内容:
//如果节点不为空
while(!n.isNull())
{
if(n.isElement()) //如果节点是元素
{
QDomElement e=n.toElement();//将其转换为元素
QDomNodeList list=e.childNodes(); // 获得元素e的所有子节点的列表
// 遍历该列表
for(int i=0;i<list.count();i++)
{
QDomNode node=list.at(i);
if(node.isElement())
qDebug()<<node.toElement().tagName();
qDebug()<<node.toElement().text();
}
}
n=n.nextSibling(); //下一个兄弟节点
}
这里使用了childNodes()函数获得了元素所有子节点的列表,然后通过遍历这个列表实现了遍历其所有子元素。运行结果:
“attrib”
“排量:2393ml”
“attrib”
“价格:43.26万元”
“attrib”
“排量:1600ml”
“attrib”
“价格:8.98万元”
“attrib”
“排量:1600ml”
“attrib”
“价格:11.25万元”
“attrib”
“排量:1997ml”
“attrib”
“价格:15.38万元”
如果没有看懂的话,完整代码可以参考:https://download.csdn.net/download/didi_ya/77137785
ok,以上便是本文的全部内容了,如果对你有所帮助,记得点个赞哟~
TypeError: can‘t convert cuda:0 device type tensor to numpy. Use Tensor.cpu()
【云原生之Docker实战】使用docker部署nacos平台
苹果手机处理器_台积电10月营收将创新高 全靠苹果A14处理器_手机
[ROC-RK3568-PC] 手把手教你把出厂的Android系统烧写为Ubuntu系统
k8s笔记14--初次体验 开源云原生软件交付平台zadig
c语言中3%3e2%3e1的值,Javascript中的空数组值
GDP越高就越幸福吗?用Python分析《世界幸福指数报告》后我们发现…
PyTorch学习—6.PyTorch数据读取机制Dataloader与Dataset
Pycocotools 报error: Microsoft Visual C++ 14.0 or greater is required. Get it with “Microsoft C++ Bui