C++ XML文件读写库tinyxpath

  1. 支持从1个xml文件的某节点加到另一个xml文件某节点;
  2. 支持xpath,关于xpath语法查看:https://www.w3school.com.cn/xpath/xpath_syntax.asp ,及例子代码tinyxpath>main.cpp(见源码)。
  3. 它包含了tinyxml,是tinyxml的超集,有关tinyxml的操作可网上查阅资料。
  4. 一个利用XPath,拷贝整个节点到另一个xml的示例:
#include  "tinyxml.h"
#include "xpath_static.h"
//...
void InsertNodes(TiXmlDocument* doc, TiXmlDocument* docCopyFrom)
{
	//增加到Site节点下
	TiXmlNode* pSiteNode = TinyXPath::XNp_xpath_node(doc->RootElement(), "/TriForma/Parts/PartFamily[@name=\"Site\"]");
	TiXmlNode* copyNode_site1 = TinyXPath::XNp_xpath_node(
		docCopyFrom->RootElement(), "/TriForma/Parts/PartFamily[@name=\"Site\"]/Part[@name=\"Cobblesand\"]"); 
	TiXmlNode* copyNode_site2 = TinyXPath::XNp_x
tinyxpath 解析简单 的小工具,输出是一个静态。可 找到xml文档. TinyXml介绍 TinyXml是一个基于DOM模型的、非验证的轻量级C++解释器 一. XML解析模型: 目前XML的解析主要有两大模型:SAX和DOM。 SAX是基于事件的,其基本工作流程是分析XML文档,当发现了一个新的元素时,产生一个对应事件,并调用相应的用户处理函数。这种方式占用内存少,速度快,但用户程序相应得会比较复杂。 DOM(文档对象模型),则是在分析时,一次性的将整个XML文档进行分析,并在内存中形成对应的树结构,同时,向用户提供一系列的接口来访问和编辑该树结构。这种方式占用内存大,速度往往慢于SAX,但可以给用户提供一个面向对象的访问接口,对用户更为友好。 另据说,一些同时提供了SAX和DOM接口的,是在底层先实现SAX,再在SAX的基础上实现DOM 对于一个特定的XML文档而言,其正确性分为两个层次。 首先是其格式应该符合XML的基本格式要求,比如第一行要有声明,标签的嵌套层次必须前后一致等等,符合这些要求的文件,就是一个合格的XML文件,称作well-formatted。 其次,一个XML文档因其内容的不同还必须在语义上符合相应的标准,这些标准由相应的DTD文件或者Schema文件来定义,符合了这些定义要求的XML文件,称作valid。 因此,解析器也分为两种,一种是验证的,即会跟据XML文件中的声明,用相应的DTD文件XML文件进行校验,检查它是否满足DTD文件的要求。另一种是忽略DTD文件,只要基本格式正确,就可以进行解析。 就我所知,验证的解析器通常都是比较重量级的。TinyXml不支持验证,但是体积很小,用在解析格式较为简单的XML文件,比如配置文件时,特别的合适。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值