自己收集的qt读写XML.doc
文本预览下载声明
自己收集的qt读写XML资料[DOM方式](有点乱)
(2010-11-01 11:22:23)
转载
标签:
杂谈 分类:Qt编程
我们可以看到,如果所要读取的XML文件不是很大,采用DOM读取方法还是很便捷的,由于我用的也是DOM树读取的方法,所以,本文所介绍的也主要是基于DOM的方法读取。
根据常用的操作,我简单的把对XML的操作分为以下几类:
1 首先对XML文件进行操作,打开文件。
这个其实就是对文件进行操作,可以把它直接定义为构造函数,在对对象进行初始化时完成。
TopoDataReader::TopoDataReader(const wstring filePath):_filePath(filePath),_qDomDoc(mydocument),_qFile(QString::fromStdWString(filePath)){ if (!_qFile.open(QIODevice::ReadOnly)) { return; }
if (!_qDomDoc.setContent(_qFile)) { _qFile.close(); return; }}
2 读取XML文件中的节点内容
假设XML文件格式如下
(1)
switchs
switch snmpip=211.87.235.136 newwork=front
/switch
/switchs
(2)
ip211.87.235.136/ip
对于第一种情况,采用如下方法:
QDomElement docElem = _qDomDoc.documentElement();
QDomNode nodeswitch=docElem.elementsByTagName(switch );//红色的为标签名
QDomElement elemnodeswitch=nodeswitch.toElement();
string snmpip=qPrintable(elemnodeswitch.attribute(snmpip));//network的也是如此方法获取
对于第二种情况,采用如下方法:
直接调用text() API就可以了
string ip=qPrintable(elementnodeip.text());
但是,假设文件中有多个同样的节点,如下
a
b/b
b/b
/a
这样用elementsByTagName(b)返回的就是一个childNodes()而不是一个单独的node了。
我们可以使用at()方法具体定位。
另外,我们还可以使用这样一种方法获取节点的值,假设XML文件如下
- +switch snmpIp=192.168.120.251 network=frontname前端主交换机/namedescription /- ipListip192.168.120.251/ip/ipListrwCommunitypublic@120/rwCommunityworkModetrue/workModeworkStatustrue/workStatusenableAlarmtrue/enableAlarmsnmpCount0/snmpCountmemoryUtilizationRatio50.0/memoryUtilizationRatiocpuUtilizationRatio50.0/cpuUtilizationRatioport161/portsnmpStatustrue/snmpStatusprivateNameCZ-5_FA/privateNameswitchIndextopLeft/switchIndex/switch我们可以先获取switch节点,然后得到其childNodes(),于是就可以使用at()方法来获取下面的每个节点了(注:从0开始)
比如说,上面的那个ip节点就是nodeswitch.childNodes().at(3)。
这样做得好处就是不用担心重复的问题,只要你确定switch节点确定对了,底下的也就一定能确定了。
3 返回某个节点下子节点的个数
这个简单,也是直接调API
QDomElement docElem = _qDomDoc.documentElement();QDomNode nodetagname=docElem.elementsByTagName(tagname).at(0);//假设有多个tagname此处选第一个int num=nodetagname.childNodes().size();
好了,临时想起来就这么多。以后想起来再添。
//===========================================
显示全部