c语言tinyxml使用方法,TinyXml使用方法[通俗易懂]

c语言tinyxml使用方法,TinyXml使用方法[通俗易懂]本文用一个详细的例子说明了TiXml的使用方法。如写、查找、插入、替换、加载、遍历等常见操作。首先简单介绍一下TinyXml,要看详细的在网上搜搜了^_^:1、TinyXml源代码只有4个cpp文件和2个头文件。2、首先要理解TinyXml中的各个基本类型之间的关系,看看这个继承图大家就会很明白了!可以看到TinyXml中的注释comment,声明declaration,元素element,文本等…

大家好,又见面了,我是你们的朋友全栈君。

本文用一个详细的例子说明了TiXml的使用方法。如写、查找、插入、替换、加载、遍历等常见操作。

首先简单介绍一下TinyXml,要看详细的在网上搜搜了^_^:

1、TinyXml源代码只有4个cpp文件和2个头文件。

2、首先要理解TinyXml中的各个基本类型之间的关系,看看这个继承图大家就会很明白了!

a4c26d1e5885305701be709a3d33442f.png

可以看到TinyXml中的注释comment

,声明declaration,元素element,文本等都是节点Node的子类,也就是说可以把XMl文件中的各个元素当做节点来处理。Node类型也有到各个子类之间的转换方法,如ToElement()转换成元素,ToDocument转换成文档等。

因此可以吧TiXmlNode作为TinyXml的基本数据类型来操作,这样转化到其他类型也比较方便!

3、Document就是整个Xml文档,Comment就是里面的注释,原始类似于HTML中的tag。

如就是一个空元素。

如 你好,其中attr1 arrt2就是ele元素的属性,”hello”

和”world”分别是相应属性的值,最后字符串“你好”就是此节点的一个文本text。

4、要理解TinyXml中的每个节点都可能是另一个节点的父节点这个很重要,因此遍历TinyXml文档要用递归的方法。每个节点都可能有

属性,文本什么的!

5、每个type of TiXmlNode节点的值’value’对应如下 :

Document: filename of the xml file

Element: name of the element

Comment: the comment text

Unknown: the tag contents

Text: the text string

6、TinyXml中Node的类型types是一个枚举类型,其成员如下:

DOCUMENT, ELEMENT, COMMENT, UNKNOWN, TEXT, and DECLARATION

7、TinyXml的在线文档和主页:

http://www.grinninglizard.com/tinyxmldocs/index.html

8、常用操作详解:

glibc[~]# cat example.cc

#include “tinyxml.h”

#include

usingnamespacestd;

TiXmlDocument *pDoc =NULL;

voidwrite_xml( )

{

TiXmlDocument doc;

TiXmlDeclaration * decl =newTiXmlDeclaration(“1.0″,””,””);

doc.LinkEndChild( decl );

TiXmlElement * element1 =newTiXmlElement(“AMULE_ToDL”);//创建元素element1

element1->SetAttribute(“num”,5);

doc.LinkEndChild( element1 );

// TiXmlText * text = new TiXmlText( “World” );//创建一个文本

// element->LinkEndChild( text );//链接

TiXmlElement * element11 =newTiXmlElement(“name”);

element11->SetAttribute(“name”,”GongFong.rmvb”);

element1->LinkEndChild( element11 );//链接element11为element1的子节点(子元素)

TiXmlElement * element2 =newTiXmlElement(“BT_ToDL”);

element2->SetAttribute(“num”,10);//创建属性

doc.LinkEndChild(element2);

//dump_to_stdout(&doc);

doc.SaveFile(“1.xml”);

}

voiddump_to_stdout( TiXmlNode* pParent )//Tixml主页上给的一个遍历方法

{

if( !pParent )return;

TiXmlNode* pChild;

TiXmlText* pText;

intt = pParent->Type();

printf(“type %d/n”, t);

intnum;

switch( t )

{

caseTiXmlNode::DOCUMENT:

printf(“Document”);

break;

caseTiXmlNode::ELEMENT:

printf(“Element [%s]”, pParent->Value() );

num=dump_attribs_to_stdout(pParent->ToElement(), indent+1);

switch(num)

{

case0: printf(” (No attributes)”);break;

case1: printf(“%s1 attribute”, getIndentAlt(indent));break;

default: printf(“%s%d attributes”, getIndentAlt(indent), num);break;

}

break;

caseTiXmlNode::COMMENT:

printf(“Comment: [%s]”, pParent->Value());

break;

caseTiXmlNode::UNKNOWN:

printf(“Unknown”);

break;

caseTiXmlNode::TEXT:

pText = pParent->ToText();

printf(“Text: [%s]”, pText->Value() );

break;

caseTiXmlNode::DECLARATION:

printf(“Declaration”);

break;

default:

break;

}

printf(“/n”);

for( pChild = pParent->FirstChild(); pChild != 0; pChild = pChild->NextSibling())

{

dump_to_stdout( pChild );

}

}

voidsearch(TiXmlNode* pParent)//遍历时候,把每个节点都是做一个父节点,即假定其都有子节点ChildNode

{

if( !pParent )return;

TiXmlNode* pChild= NULL;

intt = pParent->Type();//获取此节点的类型

if(TiXmlNode::ELEMENT == t && (strcmp(“Welcome”,pParent->Value()) == 0))//搜索元素值为”Welcome”的

{

printf(“value %s/n”,pParent->Value());//打印值

pParent->SetValue(“re-write”);//改变其属性

pParent->ToElement()->SetAttribute(“hello”,20);

TiXmlElement * element1 =newTiXmlElement(“AMULE_ToDL”);//添加一个节点

element1->SetAttribute(“num”,5);

pParent->LinkEndChild(element1);

pDoc->SaveFile();//保存文件

}

printf(“/n”);

for( pChild = pParent->FirstChild(); pChild != 0; pChild = pChild->NextSibling())

{

search(pChild);

}

}

voidsearch2(TiXmlNode* pParent)//另一种方法:

{

if( !pParent )return;

TiXmlNode* pChild= NULL;

TiXmlNode*tmp = NULL;

intt = pParent->Type();

tmp = pParent->FirstChild(“Window”);//搜索元素值为”Window”的节点

if(tmp){

//pParent->RemoveChild(tmp);//找到后删除此节点

TiXmlElement * element1 =newTiXmlElement(“AMULE_ToDL”);

element1->SetAttribute(“num”,5);

pParent->ReplaceChild(tmp,*element1);//找到”AMULE_ToDL”节点后替换此节点

}

pDoc->SaveFile();//保存文件

printf(“/n”);

for( pChild = pParent->FirstChild(); pChild != 0; pChild = pChild->NextSibling())//遍历一个节点的所兄弟节点,记着单词sibling是兄弟, 姐妹的意思

//也就是说FirstChild()和NextSibling()不是 父节点和子节点的关系

{

search2(pChild);//遍历一个节点的所有子节点

}

}

intmain(intargc,char* argv[])

{

TiXmlDocument doc(argv[1]);

boolloadOkay = doc.LoadFile();

if(loadOkay)

{

pDoc = &doc;

printf(“/n%s:/n”, argv[1]);

//dump_to_stdout( &doc ); // defined later in the tutorial

search2(&doc);//把TiXmlDocument类型的值复制给一个TiXmlNode类型

}

else

{

printf(“Failed to load file /”%s/”/n”, argv[1]);

}

return0;

}

glibc[~]# cat example.cc

#include “tinyxml.h”

#include

using namespace std;

TiXmlDocument *pDoc =NULL;

void write_xml( )

{

TiXmlDocument doc;

TiXmlDeclaration * decl = new TiXmlDeclaration( “1.0”, “”, “” );

doc.LinkEndChild( decl );

TiXmlElement * element1 = new TiXmlElement( “AMULE_ToDL” );//创建元素element1

element1->SetAttribute(“num”,5);

doc.LinkEndChild( element1 );

// TiXmlText * text = new TiXmlText( “World” );//创建一个文本

// element->LinkEndChild( text );//链接

TiXmlElement * element11 = new TiXmlElement( “name” );

element11->SetAttribute(“name”,”GongFong.rmvb”);

element1->LinkEndChild( element11 );//链接element11为element1的子节点(子元素)

TiXmlElement * element2 = new TiXmlElement( “BT_ToDL” );

element2->SetAttribute(“num”,10);//创建属性

doc.LinkEndChild(element2);

//dump_to_stdout(&doc);

doc.SaveFile( “1.xml” );

}

void dump_to_stdout( TiXmlNode* pParent )//Tixml主页上给的一个遍历方法

{

if ( !pParent ) return;

TiXmlNode* pChild;

TiXmlText* pText;

int t = pParent->Type();

printf( “type %d/n”, t);

int num;

switch ( t )

{

case TiXmlNode::DOCUMENT:

printf( “Document” );

break;

case TiXmlNode::ELEMENT:

printf( “Element [%s]”, pParent->Value() );

num=dump_attribs_to_stdout(pParent->ToElement(), indent+1);

switch(num)

{

case 0: printf( ” (No attributes)”); break;

case 1: printf( “%s1 attribute”, getIndentAlt(indent)); break;

default: printf( “%s%d attributes”, getIndentAlt(indent), num); break;

}

break;

case TiXmlNode::COMMENT:

printf( “Comment: [%s]”, pParent->Value());

break;

case TiXmlNode::UNKNOWN:

printf( “Unknown” );

break;

case TiXmlNode::TEXT:

pText = pParent->ToText();

printf( “Text: [%s]”, pText->Value() );

break;

case TiXmlNode::DECLARATION:

printf( “Declaration” );

break;

default:

break;

}

printf( “/n” );

for ( pChild = pParent->FirstChild(); pChild != 0; pChild = pChild->NextSibling())

{

dump_to_stdout( pChild );

}

}

void search(TiXmlNode* pParent)//遍历时候,把每个节点都是做一个父节点,即假定其都有子节点ChildNode

{

if ( !pParent ) return;

TiXmlNode* pChild= NULL;

int t = pParent->Type();//获取此节点的类型

if (TiXmlNode::ELEMENT == t && (strcmp(“Welcome”,pParent->Value()) == 0))//搜索元素值为”Welcome”的

{

printf(“value %s/n”,pParent->Value());//打印值

pParent->SetValue(“re-write”);//改变其属性

pParent->ToElement()->SetAttribute(“hello”,20);

TiXmlElement * element1 = new TiXmlElement( “AMULE_ToDL” );//添加一个节点

element1->SetAttribute(“num”,5);

pParent->LinkEndChild(element1);

pDoc->SaveFile(); //保存文件

}

printf( “/n” );

for ( pChild = pParent->FirstChild(); pChild != 0; pChild = pChild->NextSibling())

{

search(pChild);

}

}

void search2(TiXmlNode* pParent)//另一种方法:

{

if ( !pParent ) return;

TiXmlNode* pChild= NULL;

TiXmlNode*tmp = NULL;

int t = pParent->Type();

tmp = pParent->FirstChild(“Window”);//搜索元素值为”Window”的节点

if(tmp){

//pParent->RemoveChild(tmp);//找到后删除此节点

TiXmlElement * element1 = new TiXmlElement( “AMULE_ToDL” );

element1->SetAttribute(“num”,5);

pParent->ReplaceChild(tmp,*element1);//找到”AMULE_ToDL”节点后替换此节点

}

pDoc->SaveFile(); //保存文件

printf( “/n” );

for ( pChild = pParent->FirstChild(); pChild != 0; pChild = pChild->NextSibling()) //遍历一个节点的所兄弟节点,记着单词sibling是兄弟, 姐妹的意思

//也就是说FirstChild()和NextSibling()不是 父节点和子节点的关系

{

search2(pChild);//遍历一个节点的所有子节点

}

}

int main(int argc, char* argv[])

{

TiXmlDocument doc(argv[1]);

bool loadOkay = doc.LoadFile();

if (loadOkay)

{

pDoc = &doc;

printf(“/n%s:/n”, argv[1]);

//dump_to_stdout( &doc ); // defined later in the tutorial

search2(&doc); //把TiXmlDocument类型的值复制给一个TiXmlNode类型

}

else

{

printf(“Failed to load file /”%s/”/n”, argv[1]);

}

return 0;

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/137954.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 算法—时间复杂度[通俗易懂]

    算法—时间复杂度[通俗易懂]附录log对数:等差数列什么是等差数列?一般地,如果一个数列从第2项起,后一项与它的前一项的差等于同一个常数,那麽这个数列就叫做等差数列。这个常数叫做等差数列的公差,公差通常用字母d表示。例1:初识。-{1,3,5,7,9}公差为2-{5,15,25,35,45}公差为10-{2,68,134,200,266}公差为66-{5…

    2022年5月14日
    52
  • Python-pandas的fillna()方法-填充空值[通俗易懂]

    Python-pandas的fillna()方法-填充空值[通俗易懂]0.摘要pandas中fillna()方法,能够使用指定的方法填充NA/NaN值。1.函数详解函数形式:fillna(value=None,method=None,axis=None,inplace=False,limit=None,downcast=None,**kwargs)参数:value:用于填充的空值的值。method:{‘backfill’,…

    2022年8月12日
    8
  • html里面超链接alt_怎样用HTML代码在图片插入超链接[通俗易懂]

    html里面超链接alt_怎样用HTML代码在图片插入超链接[通俗易懂]展开全部1、图像链接图片超链接和文字超链接是一样的,在e5a48de588b63231313335323631343130323136353331333366306533图像上插入链接:点击图片,跳转页面:之间插入元素。如:。(如图)2、局部链接在某种情况下,我们不希望整张图片加链接。希望的效果是:点击图片某个区域,链接到某地址。是通过map标签和标签结合使用的。如:(1)、(2)、扩展资料:元素…

    2022年7月15日
    12
  • Linux采用yum方式安装及卸载软件

    Linux采用yum方式安装及卸载软件前言很多时候,我们在Linux中安装了软件,但是却不怎么会卸载,Linux不像Windows可以直接在控制面板中卸载。这篇文章肯定会帮助到你。收藏好了。正文1.采用yum方式安装软件yum方式安装软件是最方便的,自己一直践行的理论是能用yum绝不用源码编译,当然,yum方式的优点就是简单方便,但是它的不能自己定义安装插件,这点在我们需要自定义安装包时很不方便,在实际中,要看自己的应用场景…

    2022年6月2日
    45
  • java的this怎么理解

    java提供了一个this关键字,this关键字总是指向调用该方法的对象。根据this出现位置的不同,this作为对象的默认引用有两种情形:构造器中引用该构造器正在初始化的对象;在方法中引用调用该方法的对象。

    2022年1月17日
    54
  • 微商分销系统怎么做?[通俗易懂]

    微商分销系统怎么做?[通俗易懂]当下微商有多“火”?相信各位朋友们都很清楚,不管个户还是企业都纷纷加入这个行列,然而许多企业受困于不懂推广,形成产品销售不出的局面。那么这个问题应该怎么解决呢?此时分销悄然而至。当然,企业想要对产品展开分销,首先网站商城得具备分销功能。企业想要建立一个具备分销功能的商城分销网站?那么,微商分销…

    2022年5月17日
    32

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号