C++中rapidxml用法
转载:https://www.cnblogs.com/rainbow70626/p/7586713.html
解析xml是第三方库很多,例如:tingxml,这次学习一下rapidxml,rapidxml是一个快速的xml库,比tinyxml快了50-100倍。
这个库的下载地址为:官方网站:https://sourceforge.net/projects/rapidxml/
这个库源码一共只有四个文件分别是:

测试demo:
#include <iostream>
#include "rapidxml.hpp"
#include "rapidxml_print.hpp"
#include "rapidxml_utils.hpp" using namespace rapidxml; int CreateXml()
{
rapidxml::xml_document<> doc;
rapidxml::xml_node<>* rot = doc.allocate_node(rapidxml::node_pi, doc.allocate_string("xml version='1.0' encoding='utf-8'"));
doc.append_node(rot);
rapidxml::xml_node<>* node = doc.allocate_node(rapidxml::node_element, "config", "information");
doc.append_node(node);
rapidxml::xml_node<>* color = doc.allocate_node(rapidxml::node_element, "color", NULL);
node->append_node(color);
color->append_node(doc.allocate_node(rapidxml::node_element, "red", "0.1"));
color->append_node(doc.allocate_node(rapidxml::node_element, "green", "0.1"));
color->append_node(doc.allocate_node(rapidxml::node_element, "blue", "0.1"));
color->append_node(doc.allocate_node(rapidxml::node_element, "alpha", "1.0"));
rapidxml::xml_node<>* size = doc.allocate_node(rapidxml::node_element, "size", NULL);
size->append_node(doc.allocate_node(rapidxml::node_element, "x", ""));
size->append_node(doc.allocate_node(rapidxml::node_element, "y", ""));
node->append_node(size);
rapidxml::xml_node<>* mode = doc.allocate_node(rapidxml::node_element, "mode", "screen mode");
mode->append_attribute(doc.allocate_attribute("fullscreen", "false"));
node->append_node(mode);
std::string text;
rapidxml::print(std::back_inserter(text), doc, );
std::cout << text << std::endl;
std::ofstream out("config2.xml");
out << doc; return ;
} //读取并修改config3.xml
int ReadAndChangeXml()
{
rapidxml::file<> fdoc("config2.xml");
std::cout << fdoc.data() << std::endl;
rapidxml::xml_document<> doc;
doc.parse<>(fdoc.data());
std::cout << doc.name() << std::endl;
//! 获取根节点
rapidxml::xml_node<>* root = doc.first_node();
std::cout << root->name() << std::endl;
//! 获取根节点第一个节点
rapidxml::xml_node<>* node1 = root->first_node();
std::cout << node1->name() << std::endl;
rapidxml::xml_node<>* node11 = node1->first_node();
std::cout << node11->name() << std::endl;
std::cout << node11->value() << std::endl;
//! 修改之后再次保存
rapidxml::xml_node<>* size = root->first_node("size");
size->append_node(doc.allocate_node(rapidxml::node_element, "w", ""));
size->append_node(doc.allocate_node(rapidxml::node_element, "h", ""));
std::string text;
rapidxml::print(std::back_inserter(text), doc, );
std::cout << text << std::endl;
std::ofstream out("../config/config2.xml");
out << doc; return ;
} void createxml()
{
xml_document<> doc;
xml_node<>* root = doc.allocate_node(node_pi, doc.allocate_string("xml version='1.0' encoding='utf-8'"));
doc.append_node(root); xml_node<>* node = doc.allocate_node(node_element, "config", "information");
doc.append_node(node); xml_node<>* color = doc.allocate_node(node_element, "color", NULL);
node->append_node(color);
color->append_node(doc.allocate_node(node_element, "red", "0.1"));
color->append_node(doc.allocate_node(node_element, "green", "0.1"));
color->append_node(doc.allocate_node(node_element, "blue", "0.1"));
color->append_node(doc.allocate_node(node_element, "alpha", "0.1")); xml_node<>* size = doc.allocate_node(node_element, "size",NULL);
node->append_node(size);
size->append_node(doc.allocate_node(node_element, "x", ""));
size->append_node(doc.allocate_node(node_element, "y", ""));
xml_node<>* mode = doc.allocate_node(rapidxml::node_element, "mode", "screen mode");
mode->append_attribute(doc.allocate_attribute("fullscreen", "false"));
node->append_node(mode);
std::string text;
rapidxml::print(std::back_inserter(text), doc, );
std::cout << text << std::endl;
std::ofstream out("config.xml");
out << doc;
} void readAndChangexml()
{
file<> fdoc("config.xml"); xml_document<> doc;
std::cout << fdoc.data() << std::endl;
//doc.parse<0>(fdoc.data());//修改节点值不会保存到文件中
doc.parse<rapidxml::parse_no_data_nodes>(fdoc.data());//修改节点值会保存到文件中
std::cout << "///" << std::endl;
std::cout << doc.name() << std::endl; //获取根节点
xml_node<>* root = doc.first_node();
std::cout << root->name() << std::endl; //! 获取根节点第一个节点
xml_node<>* node1 = root->first_node();
std::cout << node1->name() << std::endl; xml_node<>* size = root->first_node("size"); xml_node<>* x = size->first_node("x");
x->value(""); std::cout << size->first_node("x")->value() << std::endl; std::string text;
print(std::back_inserter(text), doc, );
std::cout << text << std::endl;
std::ofstream out("config.xml");
out << doc;
} int main()
{
//createxml();
readAndChangexml();
//CreateXml();
//system("pause");
return ;
}
C++中rapidxml用法的更多相关文章
- C++中rapidxml用法及例子
rapidxml是一个快速的xml库,比tinyxml快了50-100倍.本文给出创建.读取.写入xml的源码. 由于新浪博客不支持文本文件上传,在使用下面代码需要先下载 rapidxml,关于这个库 ...
- C++中rapidxml用法及例子(源码)
rapidxml是一个快速的xml库,比tinyxml快了50-100倍.本文给出创建.读取.写入xml的源码. 由于新浪博客不支持文本文件上传,在使用下面代码需要先下载 rapidxml, ...
- [转载]C#中MessageBox.Show用法以及VB.NET中MsgBox用法
一.C#中MessageBox.Show用法 MessageBox.Show (String) 显示具有指定文本的消息框. 由 .NET Compact Framework 支持. MessageBo ...
- ORACLE 中ROWNUM用法总结(转)
ORACLE 中ROWNUM用法总结! 对于 Oracle 的 rownum 问题,很多资料都说不支持>,>=,=,between...and,只能用以上符号(<.<=.!=) ...
- AngularJS select中ngOptions用法详解
AngularJS select中ngOptions用法详解 一.用法 ngOption针对不同类型的数据源有不同的用法,主要体现在数组和对象上. 数组: label for value in a ...
- c#初学-多线程中lock用法的经典实例
本文转载自:http://www.cnblogs.com/promise-7/articles/2354077.html 一.Lock定义 lock 关键字可以用来确保代码块完成运行,而不会被 ...
- .NET3.5中JSON用法以及封装JsonUtils工具类
.NET3.5中JSON用法以及封装JsonUtils工具类 我们讲到JSON的简单使用,现在我们来研究如何进行封装微软提供的JSON基类,达到更加方便.简单.强大且重用性高的效果. 首先创建一个类 ...
- ORACLE 中ROWNUM用法总结!
ORACLE 中ROWNUM用法总结! 对于 Oracle 的 rownum 问题,很多资料都说不支持>,>=,=,between...and,只能用以上符号(<.<=.!=) ...
- Android开发中Bundle用法包裹数据(转)
Android开发中Bundle用法包裹数据 Bundle的经典用法,包裹数据放入Intent中,目的在于传输数据. SDK 里是这样描述: A mapping from String values ...
随机推荐
- Linux(CentOS7)下安装Mysql8数据库
一.Linux版本 二.先下载Linux下的Mysql包,打开Mysql官网 https://www.mysql.com/ 点击DOWNLOAD,进入 https://www.mysql.com/do ...
- jQuery遍历之find()
/**案例说明: *首先理清楚find()函数同children()函数之间的区别 * 1. find()会遍历给定节点下的所有的元素节点. * 2. children()之后遍历给定节点下的单一层级 ...
- 自定义View(四),onMeasure
转自:http://blog.csdn.net/a396901990/article/details/36475213 简介: 在自定义view的时候,其实很简单,只需要知道3步骤: 1.测量--on ...
- Linux GCC下strstr的实现以及一个简单的Kmp算法的接口
今天做了一道题,要用判断一个字符串是否是另一个字符串的子串,于是查了一下strstr的实现. 代码如下: char *strstr(const char*s1,const char*s2) { con ...
- 字符流,字节流,属性集(Properties)
字节输入流(InputStream) java.io.InputStream抽象类是表示字节输入流的所有类的超类.可以读取字节信息到内存中.它定义了字节输入流的基本共性功能方法. public voi ...
- Solr的集群搭建(索引库)
Solr的集群的搭建 Solr集群原理 SolrCloud概念以及结构 概念: SolrCloud(Solr云)是Solr提供的分布式搜索方案,当你需要大规模,容错,分布式索引和检索能力时使用Solr ...
- OpenGL是什么?GPU是什么?
一.GPU与CPU CPU是处理基本算数运算的单元:它处理的数据是数:整型.浮点型.bool等等: GPU是处理图形运算的单元:它处理的数据是图形的数据矩阵: GPU的输入是一个和多个图形,输出是 ...
- Content-Type与MIME
http://www.cnblogs.com/jsean/articles/1610265.html 首先,我们要了解浏览器是如何处理内容的.在浏览器中显示的内容有 HTML.有 XML.有 GIF. ...
- PHP:ThinkCMFX任意文件包含漏洞
前言:最近爆出来的漏洞,ThinkCmfX版本应该是通杀的,基于3.X Thinkphp开发的 代码下载地址:https://gitee.com/thinkcmf/ThinkCMFX/releases ...
- [Algorithm] 283. Move Zeroes
Given an array nums, write a function to move all 0's to the end of it while maintaining the relativ ...