在TinyXML中,根据XML的各种元素来定义了一些类:
        TiXmlBase:整个TinyXML模型的基类。
        TiXmlAttribute:对应于XML中的元素的属性。
        TiXmlNode:对应于DOM结构中的节点。
        TiXmlComment:对应于XML中的注释。
        TiXmlDeclaration:对应于XML中的申明部分,即<?versiong="1.0" ?>。
        TiXmlDocument:对应于XML的整个文档。
        TiXmlElement:对应于XML的元素。
        TiXmlText:对应于XML的文字部分。
        TiXmlUnknown:对应于XML的未知部分。 
        TiXmlHandler:定义了针对XML的一些操作。

例如:

tinyxml使用笔记与总结<?xml version="1.0" standalone=no>
tinyxml使用笔记与总结<!– Our to do list data –>
tinyxml使用笔记与总结<ToDo>
tinyxml使用笔记与总结<Item priority="1"> Go to the <bold>Toy store!</bold></Item>
tinyxml使用笔记与总结<Item priority="2"> Do bills</Item>
tinyxml使用笔记与总结</ToDo> 



整个对象树: 

TiXmlDocument "demo.xml"
TiXmlDeclaration "version=’1.0′" "standalone=no"
TiXmlComment " Our to do list data"
TiXmlElement "ToDo"
TiXmlElement "Item" Attribtutes: priority = 1
TiXmlText "Go to the "
TiXmlElement "bold"
TiXmlText "Toy store!"
TiXmlElement "Item" Attributes: priority=2
TiXmlText "Do bills" 

tinyXML中,用FirstChild"名字"时,FirstChild函数的点与要找的点必父子

句柄

想要健壮地读取一个XML文档,检查方法调用后的返回值是否为null是很重要的。一种安全的检错实现可能会产生像这样的代码: 

 

tinyxml使用笔记与总结TiXmlElement* root = document.FirstChildElement( "Document" );
tinyxml使用笔记与总结
if ( root )



用句柄的话就不会这么冗长了,使用TiXmlHandle类,前面的代码就会变成这样: 

tinyxml使用笔记与总结TiXmlHandle docHandle( &document );
tinyxml使用笔记与总结TiXmlElement
* child2 = docHandle.FirstChild( "Document" ).FirstChild( "Element" ).Child( "Child"1 ).ToElement();
tinyxml使用笔记与总结
if ( child2 )

一、读取XML,设置节点文本
如下XML片段:

tinyxml使用笔记与总结<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>
tinyxml使用笔记与总结
<ZXML>
tinyxml使用笔记与总结    
<ZAPP>
tinyxml使用笔记与总结         
<VBS_RUNTIME_PARAMS>
tinyxml使用笔记与总结               
<BROADCAST_VERSION info="版本">8</BROADCAST_VERSION>
tinyxml使用笔记与总结               
<Broadcast>
tinyxml使用笔记与总结                
<FileCount info="资源文件个数">69</FileCount>
tinyxml使用笔记与总结                
<SOURCE_1>
tinyxml使用笔记与总结                    
<ID info="图片编号">1</ID>
tinyxml使用笔记与总结                    
<Version info="图片版本">1</Version>
tinyxml使用笔记与总结                    
<Path info="图片路径">/mnt/share/1.bmp</Path>
tinyxml使用笔记与总结                    
<FileMode info="文件处理模式">0</FileMode>
tinyxml使用笔记与总结                
</SOURCE_1>
tinyxml使用笔记与总结                
<SOURCE_2>
tinyxml使用笔记与总结                    
<Path info="图片路径">/mnt/share/2.bmp</Path>
tinyxml使用笔记与总结                    
<ID info="图片编号">2</ID>
tinyxml使用笔记与总结                    
<Version info="图片版本">1</Version>
tinyxml使用笔记与总结                    
<FileMode info="文件处理模式">0</FileMode>
tinyxml使用笔记与总结                
</SOURCE_2>
tinyxml使用笔记与总结                tinyxml使用笔记与总结tinyxml使用笔记与总结.
tinyxml使用笔记与总结                
</Broadcast>
tinyxml使用笔记与总结         
</VBS_RUNTIME_PARAMS>
tinyxml使用笔记与总结    
</ZAPP>
tinyxml使用笔记与总结
</ZXML>


要设置BROADCAST_VERSION节点的值 8为其他值,可参考如下代码(将值加1):
用ReplaceChild( TiXmlNode* replaceThis, const TiXmlNode& withThis )方法替换

tinyxml使用笔记与总结    TiXmlDocument doc("zapp.conf");
tinyxml使用笔记与总结    doc.LoadFile();
tinyxml使用笔记与总结    TiXmlHandle docHandle( 
&doc );
tinyxml使用笔记与总结TiXmlElement
* Broadcast_ver = docHandle.FirstChild("ZXML").FirstChild("ZAPP").FirstChild("VBS_RUNTIME_PARAMS").FirstChildElement("BROADCAST_VERSION").ToElement();
tinyxml使用笔记与总结    TiXmlNode 
* oldnode =  Broadcast_ver->FirstChild();
tinyxml使用笔记与总结    
const char *ver = Broadcast_ver->GetText();
tinyxml使用笔记与总结    
int oldVer = atoi(ver);
tinyxml使用笔记与总结    CString newVer;
tinyxml使用笔记与总结    newVer.Format(
"%d",oldVer+1);
tinyxml使用笔记与总结    TiXmlText newText(newVer);
tinyxml使用笔记与总结    Broadcast_ver
->ReplaceChild(oldnode,newText);
tinyxml使用笔记与总结    AfxMessageBox(Broadcast_ver
->GetText());//输出值
tinyxml使用笔记与总结    
doc.SaveFile();

二,删除节点,属性值

RemoveChild( TiXmlNode* removeThis )方法删除父节点的子节点,
RemoveAttribute( const char * name )方法删除属性值.

例如删除BROADCAST_VERSION节点

tinyxml使用笔记与总结TiXmlHandle docHandle( &doc );
tinyxml使用笔记与总结    TiXmlElement
* Broadcast_ver = docHandle.FirstChild("ZXML").FirstChild("ZAPP").FirstChild("VBS_RUNTIME_PARAMS").ToElement();
tinyxml使用笔记与总结
tinyxml使用笔记与总结    TiXmlNode 
* node =  Broadcast_ver->FirstChild("BROADCAST_VERSION");
tinyxml使用笔记与总结
tinyxml使用笔记与总结    Broadcast_ver
->RemoveChild(node);

也可以删除整个SOURCE_1节点:

tinyxml使用笔记与总结TiXmlHandle docHandle( &doc );
tinyxml使用笔记与总结    TiXmlElement
* Broadcast = docHandle.FirstChild("ZXML").FirstChild("ZAPP").FirstChild("VBS_RUNTIME_PARAMS").FirstChild("Broadcast").ToElement();
tinyxml使用笔记与总结
tinyxml使用笔记与总结    TiXmlNode 
* node =  Broadcast->FirstChild("SOURCE_1");
tinyxml使用笔记与总结
tinyxml使用笔记与总结    Broadcast
->RemoveChild(node);

删除BROADCAST_VERSION的info属性:

tinyxml使用笔记与总结TiXmlHandle docHandle( &doc );
tinyxml使用笔记与总结    TiXmlElement
* Broadcast_ver = docHandle.FirstChild("ZXML").FirstChild("ZAPP").FirstChild("VBS_RUNTIME_PARAMS").FirstChildElement("BROADCAST_VERSION").ToElement();
tinyxml使用笔记与总结
tinyxml使用笔记与总结    Broadcast_ver
->RemoveAttribute("info"); //删除info

可以借助NextSiblingElement()方法实现递归删除.

三,添加节点,属性值

例如在SOURCE_3下添加BROADCAST_PID节点:

tinyxml使用笔记与总结TiXmlHandle docHandle( &doc );
tinyxml使用笔记与总结    TiXmlElement
* Broadcast = docHandle.FirstChild("ZXML").FirstChild("ZAPP").FirstChild("VBS_RUNTIME_PARAMS").FirstChild("Broadcast").ToElement();
tinyxml使用笔记与总结    TiXmlElement
* Broadcast_Pid = new TiXmlElement("BROADCAST_PID");
tinyxml使用笔记与总结    TiXmlText 
*text =new TiXmlText("7215");
tinyxml使用笔记与总结    Broadcast_Pid
->SetAttribute("info","the pid");
tinyxml使用笔记与总结    Broadcast_Pid
->LinkEndChild(text);
tinyxml使用笔记与总结    Broadcast
->LinkEndChild(Broadcast_Pid);

将在SOURCE_3后添加新的节点:

tinyxml使用笔记与总结<BROADCAST_PID info="the pid">7215</BROADCAST_PID>

四,最后说一下中文乱码的问题

乱码是由于GB2312与UTF8之间转换不当造成的,tinyxml在处理UTF8本身没有问题,当你打开一个UTF8的文档,可以在加载的时候指定UTF8的方式,或者文档声明处指明的编码格式,tinyxml会按照相应的编码格式加载,但很多时候当我们输出或写入中文字段时会出现乱码,无论在内存,还是打印出来的内容.这是因为我们的软件通常是GB2312编码,而读取或写入的内容是UTF8,自然就会出错.可以借助网上的两个函数来实现转换(原作者不详):

tinyxml使用笔记与总结    void ConvertUtf8ToGBK(CString& strUtf8) 
    }

当然,你也可以用MultiByteToWideChar,WideCharToMultiByte函数自己实现转换.以上是简单应用的几个举例,理解他们,相信你已经能写出满足自己需要的代码了.

 

相关文章:

  • 2021-12-08
  • 2021-11-21
  • 2021-08-19
  • 2022-12-23
  • 2021-04-02
  • 2021-12-19
猜你喜欢
  • 2021-11-09
  • 2021-07-10
  • 2021-06-16
  • 2022-01-13
  • 2021-08-09
  • 2021-10-10
  • 2021-09-04
相关资源
相似解决方案