【xml】[Qt] 生成xml格式对象或xml字符串(速成 QT处理xml)

本文为什么称为速成呢,因为本人就是速成的,接手的项目里有个关于xml的bug,对xml一无所知到解决bug,自己硬着头皮上,速成成功了,也就觉得有写点什么东西的必要了,便有了此文,也算是为了以后的自己用的时候看了。

快速入门xml

1.xml是一种有树状结构的标记语言,适合数据传输
大致格式如下

<?xml version="1.0" encoding="utf-8"?>
<book>
  <bookID>9996666</bookID>
  <DATA>
    <page>2011041222150076</page>
  </DATA>
</book>

2.我们大致将其分为3个部分(我乱说的 有时间不用速成的建议看其他文章 别被我误导)

  • 头部 固定这么写就行,表示了这种数据是xml,版本号和字符集
<?xml version="1.0" encoding="utf-8"?>
  • 元素节点 <book> 这样的都是元素 从 <book>到 <\book>都属于元素,我们把book称为元素名吧 方便后面叙述(我定义的 请有空了查询正确的官方定义)
  • 文本节点 9996666 和 2011041222150076这样的节点
    如果你不理解这文本为何是节点,你可以换个格式这么看该xml
<?xml version="1.0" encoding="utf-8"?>
<book>
  <bookID>
    9996666
  </bookID>
  <DATA>
    <page>
      2011041222150076 //将其理解为叶子节点
    </page>
  </DATA>
</book>

3.以上三个部分+树状结构嵌套就组成了我们的xml

另:有个概念叫元素的属性 类似<person sex=“female”>
, 官方文档建议避免使用,所以这里速成也不提了

速成qt对xml的处理

1.首先这玩意在QtXml库里,代码里加个#include <QtXml>先

2.前面说了xml是树状结构,我们称为文档树,那就会有个根来代表整个树用来处理,我们写下如下代码 ,以后domDoc就代表一个xml文档树数据了,我们对该xml的处理都需要这个domDoc。

QDomDocument domDoc;

3.神说,要有头,于是便有了以下代码

	domDoc.appendChild(domDoc.createProcessingInstruction("xml", "version=\"1.0\" encoding=\"utf-8\""));

不需要刨根问底,此处添加xml的头部,一个xml只需要一次

4.神看xml是好的,如何给该xml创建元素节点? 我们先创建个最底层的page元素

		QDomElement pageEle = domDoc.createElement("page");

这样我们就有了 <page>到 <\page>

5.但是元素是空的?

	pageEle.appendChild(domDoc.createTextNode("2011041222150076"));

即 元素.appendChild(文档树的根.createTextNode(文本 )) 此时我们生成了一个带文本节点2011041222150076的元素page

6.开始套娃 ,创建其他元素,并给其添加父子元素关联

	QDomElement dataEle = domDoc.createElement("DATA");
	dataEle.appendChild(pageEle);

类似上面这样,等我们添加到domDoc,这颗树就完成了

	domDoc.appendChild(bookEle); //省略了其他元素的创建

7.完成 我们需要用到这棵树,就使用domDoc来调用,或者把他转成字符串来传输或处理

QString xmlStr = domDoc.toString(); //一个string类型的xml字符串
  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用JavaScript内置的XML解析器DOMParser来解析XML文件或XML格式字符串。下面是一个示例代码: ```javascript // 定义一个XML格式字符串 var xmlString = '<root><person><name>张三</name><age>18</age></person></root>'; // 创建一个DOMParser对象 var parser = new DOMParser(); // 解析XML字符串 var xmlDoc = parser.parseFromString(xmlString, 'text/xml'); // 获取XML文档中的元素 var name = xmlDoc.getElementsByTagName('name')[0].childNodes[0].nodeValue; var age = xmlDoc.getElementsByTagName('age')[0].childNodes[0].nodeValue; // 打印结果 console.log('name:', name); console.log('age:', age); ``` 在上面的代码中,我们首先定义了一个XML格式字符串,然后创建了一个DOMParser对象,使用parseFromString方法来解析XML字符串,最后从解析后的文档中获取元素并打印结果。 如果要解析XML文件,可以使用XMLHttpRequest对象来获取XML文件内容,然后再使用DOMParser解析。具体代码请参考下面的示例: ```javascript // 创建XMLHttpRequest对象 var xhr = new XMLHttpRequest(); // 发送GET请求获取XML文件内容 xhr.open('GET', 'example.xml', true); xhr.send(); // 监听XML文件加载完成事件 xhr.onreadystatechange = function() { if (xhr.readyState == 4 && xhr.status == 200) { // 获取XML文件内容 var xmlString = xhr.responseText; // 创建DOMParser对象 var parser = new DOMParser(); // 解析XML字符串 var xmlDoc = parser.parseFromString(xmlString, 'text/xml'); // 获取XML文档中的元素 var name = xmlDoc.getElementsByTagName('name')[0].childNodes[0].nodeValue; var age = xmlDoc.getElementsByTagName('age')[0].childNodes[0].nodeValue; // 打印结果 console.log('name:', name); console.log('age:', age); } }; ``` 在上面的代码中,我们创建了一个XMLHttpRequest对象,使用GET请求获取XML文件内容,然后使用DOMParser解析XML字符串,最后从解析后的文档中获取元素并打印结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值