转载: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用法的更多相关文章

  1. C++中rapidxml用法及例子

    rapidxml是一个快速的xml库,比tinyxml快了50-100倍.本文给出创建.读取.写入xml的源码. 由于新浪博客不支持文本文件上传,在使用下面代码需要先下载 rapidxml,关于这个库 ...

  2. C++中rapidxml用法及例子(源码)

    rapidxml是一个快速的xml库,比tinyxml快了50-100倍.本文给出创建.读取.写入xml的源码.      由于新浪博客不支持文本文件上传,在使用下面代码需要先下载 rapidxml, ...

  3. [转载]C#中MessageBox.Show用法以及VB.NET中MsgBox用法

    一.C#中MessageBox.Show用法 MessageBox.Show (String) 显示具有指定文本的消息框. 由 .NET Compact Framework 支持. MessageBo ...

  4. ORACLE 中ROWNUM用法总结(转)

    ORACLE 中ROWNUM用法总结! 对于 Oracle 的 rownum 问题,很多资料都说不支持>,>=,=,between...and,只能用以上符号(<.<=.!=) ...

  5. AngularJS select中ngOptions用法详解

    AngularJS select中ngOptions用法详解   一.用法 ngOption针对不同类型的数据源有不同的用法,主要体现在数组和对象上. 数组: label for value in a ...

  6. c#初学-多线程中lock用法的经典实例

    本文转载自:http://www.cnblogs.com/promise-7/articles/2354077.html 一.Lock定义     lock 关键字可以用来确保代码块完成运行,而不会被 ...

  7. .NET3.5中JSON用法以及封装JsonUtils工具类

    .NET3.5中JSON用法以及封装JsonUtils工具类  我们讲到JSON的简单使用,现在我们来研究如何进行封装微软提供的JSON基类,达到更加方便.简单.强大且重用性高的效果. 首先创建一个类 ...

  8. ORACLE 中ROWNUM用法总结!

    ORACLE 中ROWNUM用法总结! 对于 Oracle 的 rownum 问题,很多资料都说不支持>,>=,=,between...and,只能用以上符号(<.<=.!=) ...

  9. Android开发中Bundle用法包裹数据(转)

    Android开发中Bundle用法包裹数据 Bundle的经典用法,包裹数据放入Intent中,目的在于传输数据. SDK 里是这样描述: A mapping from String values ...

随机推荐

  1. LP线性规划初识

    认识LP 线性规划(Linear Programming) 特指目标函数和约束条件皆为线性的最优化问题. 目标函数: 多个变量形成的函数 约束条件: 由多个等式/不等式形成的约束条件 线性规划: 在线 ...

  2. 捕获Ctrl + C中断 优雅的退出程序 golang

    捕获Ctrl + C中断 优雅的退出程序 Gracefully terminate a program in Go os/signal 来捕获系统中断等信号 // Notify方法将signal发送到 ...

  3. Linux(Redhat)传送门汇总

    Linux(Redhat)传送门汇总 linux 环境布置 常用命令与shell 常用命令 shell 环境布置 Linux虚拟机安装(rhel 7.4) 虚拟机网络设置 VMware虚拟机开机启动 ...

  4. dfs 解决(隐式)图搜索问题

    132. 单词搜索 II 中文 English 给出一个由小写字母组成的矩阵和一个字典.找出所有同时在字典和矩阵中出现的单词.一个单词可以从矩阵中的任意位置开始,可以向左/右/上/下四个相邻方向移动. ...

  5. 某个新闻网站抓去自媒体账号 queryId js破解

    第一步: 发现加密 第二部:搜索加密参数 queryId 第三部:找到js核心加密代码 第四部:代码实现 window = {} function utf8ToBase64(t) { console. ...

  6. Spring Boot 缓存 知识点

    每次调用需要缓存功能的方法时,Spring会检查指定参数的指定的目标方法是否已经被调用过:如果有就直接从缓存中获取方法调用后的结果,如果没有就调用方法并缓存结果后返回给用户.下次调用直接从缓存中获取. ...

  7. maven中jar冲突解决

    Maven中jar包冲突是开发过程中比较常见而又令人头疼的问题,我们需要知道 jar包冲突的原理,才能更好的去解决jar包冲突的问题.本文将从jar包冲突的原理和解决两个方面阐述Maven中jar包冲 ...

  8. sqoop2相关实例:hdfs和mysql互相导入(转)

    原文地址:http://blog.csdn.net/dream_an/article/details/74936066 超详细讲解Sqoop2应用与实践 2017年07月10日 20:06:57 阅读 ...

  9. swift是面向对象、面向协议、高阶类型、灵活扩展、函数式编程语言

    swift是面向对象.面向协议.高阶类型.灵活扩展.函数式编程语言

  10. 理解serverless无服务架构原理(一)

    阅读目录 一:什么是serverless无服务? 二:与传统模式架构区别? 三:serverless优缺点? 四:使用serverless的应用场景有哪些? 回到顶部 一:什么是serverless无 ...