在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的一些操作。



例如:

<?xml version="1.0" standalone=no>

<!– Our to do list data –>

<ToDo>

<Item priority="1"> Go to the <bold>Toy store!</bold></Item>

<Item priority="2"> Do bills</Item>

</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是很重要的。一种安全的检错实现可能会产生像这样的代码:

TiXmlElement* root = document.FirstChildElement( "Document" );

if ( root )

{

TiXmlElement* element = root->FirstChildElement( "Element" );

if ( element )

{

TiXmlElement* child = element->FirstChildElement( "Child" );

if ( child )

{

TiXmlElement* child2 = child->NextSiblingElement( "Child" );

if ( child2 )

{

// Finally do something useful. 

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

TiXmlHandle docHandle( &document );

TiXmlElement* child2 = docHandle.FirstChild( "Document" ).FirstChild( "Element" ).Child( "Child", 1 ).ToElement();

if ( child2 )

{

// do something useful 

一、读取XML,设置节点文本

如下XML片段:

<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>

<ZXML>

    <ZAPP>

         <VBS_RUNTIME_PARAMS>

               <BROADCAST_VERSION info="版本">8</BROADCAST_VERSION>

               <Broadcast>

                <FileCount info="资源文件个数">69</FileCount>

                <SOURCE_1>

                    <ID info="图片编号">1</ID>

                    <Version info="图片版本">1</Version>

                    <Path info="图片路径">/mnt/share/1.bmp</Path>

                    <FileMode info="文件处理模式">0</FileMode>

                </SOURCE_1>

                <SOURCE_2>

                    <Path info="图片路径">/mnt/share/2.bmp</Path>

                    <ID info="图片编号">2</ID>

                    <Version info="图片版本">1</Version>

                    <FileMode info="文件处理模式">0</FileMode>

                </SOURCE_2>

                .

                </Broadcast>

         </VBS_RUNTIME_PARAMS>

    </ZAPP>

</ZXML>

要设置BROADCAST_VERSION节点的值 8为其他值,可参考如下代码(将值加1):

用ReplaceChild( TiXmlNode* replaceThis, const TiXmlNode& withThis )方法替换

    TiXmlDocument doc("zapp.conf");

    doc.LoadFile();

    TiXmlHandle docHandle( &doc );

TiXmlElement* Broadcast_ver = docHandle.FirstChild("ZXML").FirstChild("ZAPP").FirstChild("VBS_RUNTIME_PARAMS").FirstChildElement("BROADCAST_VERSION").ToElement();

    TiXmlNode * oldnode =  Broadcast_ver->FirstChild();

    const char *ver = Broadcast_ver->GetText();

    int oldVer = atoi(ver);

    CString newVer;

    newVer.Format("%d",oldVer+1);

    TiXmlText newText(newVer);

    Broadcast_ver->ReplaceChild(oldnode,newText);

    AfxMessageBox(Broadcast_ver->GetText());//输出值

    doc.SaveFile();

二,删除节点,属性值



RemoveChild( TiXmlNode* removeThis )方法删除父节点的子节点,

RemoveAttribute( const char * name )方法删除属性值.



例如删除BROADCAST_VERSION节点

TiXmlHandle docHandle( &doc );

    TiXmlElement* Broadcast_ver = docHandle.FirstChild("ZXML").FirstChild("ZAPP").FirstChild("VBS_RUNTIME_PARAMS").ToElement();



    TiXmlNode * node =  Broadcast_ver->FirstChild("BROADCAST_VERSION");



    Broadcast_ver->RemoveChild(node);

也可以删除整个SOURCE_1节点:

TiXmlHandle docHandle( &doc );

    TiXmlElement* Broadcast = docHandle.FirstChild("ZXML").FirstChild("ZAPP").FirstChild("VBS_RUNTIME_PARAMS").FirstChild("Broadcast").ToElement();



    TiXmlNode * node =  Broadcast->FirstChild("SOURCE_1");



    Broadcast->RemoveChild(node);

删除BROADCAST_VERSION的info属性:

TiXmlHandle docHandle( &doc );

    TiXmlElement* Broadcast_ver = docHandle.FirstChild("ZXML").FirstChild("ZAPP").FirstChild("VBS_RUNTIME_PARAMS").FirstChildElement("BROADCAST_VERSION").ToElement();



    Broadcast_ver->RemoveAttribute("info"); //删除info

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



三,添加节点,属性值



例如在SOURCE_3下添加BROADCAST_PID节点:

TiXmlHandle docHandle( &doc );

    TiXmlElement* Broadcast = docHandle.FirstChild("ZXML").FirstChild("ZAPP").FirstChild("VBS_RUNTIME_PARAMS").FirstChild("Broadcast").ToElement();

    TiXmlElement* Broadcast_Pid = new TiXmlElement("BROADCAST_PID");

    TiXmlText *text =new TiXmlText("7215");

    Broadcast_Pid->SetAttribute("info","the pid");

    Broadcast_Pid->LinkEndChild(text);

    Broadcast->LinkEndChild(Broadcast_Pid);

将在SOURCE_3后添加新的节点:

<BROADCAST_PID info="the pid">7215</BROADCAST_PID>

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



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

    void ConvertUtf8ToGBK(CString& strUtf8) 

    {

        int len=MultiByteToWideChar(CP_UTF8, 0, (LPCTSTR)strUtf8, -1, NULL,0);

        unsigned short * wszGBK = new unsigned short[len+1];

        memset(wszGBK, 0, len * 2 + 2);

        MultiByteToWideChar(CP_UTF8, 0, (LPCTSTR)strUtf8, -1, wszGBK, len);



        len = WideCharToMultiByte(CP_ACP, 0, wszGBK, -1, NULL, 0, NULL, NULL);

        char *szGBK=new char[len + 1];

        memset(szGBK, 0, len + 1);

        WideCharToMultiByte (CP_ACP, 0, wszGBK, -1, szGBK, len, NULL,NULL);



        strUtf8 = szGBK;

        delete[] szGBK;

        delete[] wszGBK;

    }





    void ConvertGBKToUtf8(CString& strGBK)

    {

        int len=MultiByteToWideChar(CP_ACP, 0, (LPCTSTR)strGBK, -1, NULL,0);

        unsigned short * wszUtf8 = new unsigned short[len+1];

        memset(wszUtf8, 0, len * 2 + 2);

        MultiByteToWideChar(CP_ACP, 0, (LPCTSTR)strGBK, -1, wszUtf8, len);



        len = WideCharToMultiByte(CP_UTF8, 0, wszUtf8, -1, NULL, 0, NULL, NULL);

        char *szUtf8=new char[len + 1];

        memset(szUtf8, 0, len + 1);

        WideCharToMultiByte (CP_UTF8, 0, wszUtf8, -1, szUtf8, len, NULL,NULL);



        strGBK = szUtf8;

        delete[] szUtf8;

        delete[] wszUtf8;

    }

tinyxml学习一的更多相关文章

  1. tinyxml学习4

    tinyXML一款很优秀的操作C++类库,文件不大,但方法很丰富,和apache的Dom4j可以披靡啊!习惯了使用java类库的我看到这么丰富的c++类库,很高兴!它使用很简单,只需要拷贝几个文件到你 ...

  2. tinyxml学习5

    读取和设置xml配置文件是最常用的操作,试用了几个C++的XML解析器,个人感觉TinyXML是使用起来最舒服的,因为它的API接口和Java的十分类似,面向对象性很好. TinyXML是一个开源的解 ...

  3. tinyxml学习2

    在TinyXML中,根据XML的各种元素来定义了一些类: TiXmlBase:整个TinyXML模型的基类. TiXmlAttribute:对应于XML中的元素的属性. TiXmlNode:对应于DO ...

  4. TinyXML学习:TiXmlBase类

    TiXmlBase: 作为整个TinyXML模型的基类,除了可以提供一些实用功能外,它几乎没有什么作用 TiXmlBase的友元类: friend class TiXmlNode; friend cl ...

  5. tiny学习3

    这几天在埋头写自己的个星期!而且由于它是基于事件发生的次序(小时就把我的文件导出来了--呵呵.在阅读本文之前,请先看看我Blog里转贴的<TinyXML学习笔记>,相信它能给各位一个关于T ...

  6. tiny xml 使用总结

    这几天在埋头写自己的3D文件浏览器(稍后发布),突发奇想的要把自己的内部格式转化成XML,于是,把以前在研究所时用过的ExPat翻了出来.ExPat是基于事件的XML解释器,速度挺快的,但结构方面有点 ...

  7. Android源码-学习随笔

    在线代码网站1:http://grepcode.com/project/repository.grepcode.com/java/ext/com.google.android/android/ 书籍: ...

  8. 值得学习的C语言开源项目

    值得学习的C语言开源项目   - 1. Webbench Webbench是一个在linux下使用的非常简单的网站压测工具.它使用fork()模拟多个客户端同时访问我们设定的URL,测试网站在压力下工 ...

  9. C++著名程序库的比较和学习经验 (转)

    转自:http://www.open-open.com/lib/view/open1328670468108.html 内容目录: 1.C++各大有名库的介绍——C++标准库 2.C++各大有名库的介 ...

随机推荐

  1. linux kernel 如何处理大小端

    暂时在用MPC8309,不太清楚大小端内核是什么时候给转的. 今天看了关于readl和writel具体实现的文章 今天就主要来分析下readl/writel如何实现高效的数据swap和寄存器读写.我们 ...

  2. C# WinForm控件之Dock顺序调整

    最近被.net winform中的控件布局搞困惑了,由于控件都是使用Dock方式的,操作起来也是比较方便,如果最大化,窗口大小调整等,都可以随着窗口大小的变化而变化. 但问题是,.net winfor ...

  3. CSS篇章

    页面的组成:页面=数据(后台技术jsp|asp|.net|php|python)+Html(显示)+CSS(样式)+js(动效) CSS:层叠样式表        特点:①CSS和HTML分离    ...

  4. Struts2之过滤器和拦截器的区别

    刚学习Struts2这个框架不久,心中依然有一个疑惑未解那就是过滤器和拦截器的区别,相信也有不少人跟我一样对于这个问题没有太多的深入了解 那么下面我们就一起来探讨探讨 过滤器,是在java web中, ...

  5. Linux压缩那些事儿

    tar简介 Linux的压缩命令的源文件只能有一个,这意味在压缩之前不得不先将要压缩的所有文件打包成一个包,然后再压缩包,这样来完成对多个文件的压缩.所以在了解解压缩之前就必须先了解打包命令. Lin ...

  6. Centos7.2 Systemd 方式编译 Mysql5.7.11

    导读 MySQL 5.7 版本的发布,也就是说从现在开始5.7已经可以在生产环境中使用,有任何问题官方都将立刻修复. MySQL 5.7主要特性: 原生支持Systemd 更好的性能:对于多核CPU. ...

  7. 腾讯优测| 让Android屏幕适配开发更简单-Google百分比布

    文/腾讯优测工程师 吴宇焕 腾讯优测优社区干货精选~ 相信开发同学都被安卓设备碎片化的问题折磨过,市面上安卓手机的主流屏幕尺寸种类繁多,给适配造成很大的困难.就算搞定了屏幕尺寸问题,各种分辨率又让人眼 ...

  8. TCP链接时主动close时可能的rst报文

    阿里核心系统团队博客http://csrd.aliapp.com/?p=1055记录了主动关闭TCP socket时,可能不发fin包,而是发rst的问题. 其原因是主动关闭socket时,若接收bu ...

  9. 2015GitWebRTC编译实录15

    各个库编译完成后,整合talkapp,联编时还是碰到了一些问题,主要是lib里的源码文件被错误移走,或者宏定义等有问题的,不一而足 FQ访问https://apprtc.appspot.com/,拿到 ...

  10. iOS常用设计模式和机制之代理

    Delegate : 1 代理设计模式的使用我们首先需要明白三个要素 *委托方:委托别人去执行某些操作的人(对象) *代理方:被委托区执行某些操作的人(对象) *协议:(protocol)委托方需要代 ...