XML使用指导

·转自:http://www.cppblog.com/elva/archive/2008/04/24/47907.html

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

例如:

<? xmlversion="1.0"standalone=no>
<!–Ourtodolistdata–>
<Todo>
<Itempriority="1">Gotothe<bold>Toystore!</bold></Item>
<Itempriority="2">dobills</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)
{
//Finallydosomethinguseful.



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

tixmlHandledocHandle(&document);
tixmlElement*child2=docHandle.FirstChild("Document").FirstChild("Element").Child("Child",1).toElement();
if(child2)
{
dosomethinguseful

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

xmlversion="1.0"encoding="UTF-8"standalone="yes" ?>
< ZXML >
ZAPP VBS_RUNTIME_ParaMS broADCAST_VERSION info ="版本" >8 </ broADCAST_VERSION broadcast FileCount ="资源文件个数" >69 FileCount SOURCE_1 ID ="图片编号" >1 ID Version ="图片版本" Version Path ="图片路径" >/mnt/share/1.bmp Path FileMode ="文件处理模式" >0 FileMode SOURCE_2 >/mnt/share/2.bmp >2 >
.
>

要设置broADCAST_VERSION节点的值 8为其他值,可参考如下代码(将值加1):
用ReplaceChild( tixmlNode* replaceThis,const tixmlNode& withThis )方法替换
tixmlDocumentdoc("zapp.conf");
doc.LoadFile();
tixmlHandledocHandle(&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();
intoldVer=atoi(ver);
CStringnewVer;
newVer.Format("%d",oldVer+1);
tixmlTextnewText(newVer);
broadcast_ver->ReplaceChild(oldnode,newText);
AfxMessageBox(broadcast_ver->GetText()); // 输出
doc.SaveFile();

二,删除节点,属性
RemoveChild( tixmlNode* removeThis )方法删除父节点的子节点,
RemoveAttribute( const char * name )方法删除属性值.
例如删除broADCAST_VERSION节点
tixmlHandledocHandle(&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节点:
tixmlHandledocHandle(&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属性:
tixmlHandledocHandle(&doc);
tixmlElement*broadcast_ver=docHandle.FirstChild("ZXML").FirstChild("ZAPP").FirstChild("VBS_RUNTIME_ParaMS").FirstChildElement("broADCAST_VERSION").toElement();

broadcast_ver->RemoveAttribute("info"); 删除info

可以借助NextSiblingElement()方法实现递归删除.
三,添加节点,sans-serif; font-size:14px; line-height:20.25px">例如在SOURCE_3下添加broADCAST_PID节点:
tixmlHandledocHandle(&doc);
tixmlElement*broadcast=docHandle.FirstChild("ZXML").FirstChild("ZAPP").FirstChild("VBS_RUNTIME_ParaMS").FirstChild("broadcast").toElement();
tixmlElement*broadcast_Pid= newtixmlElement("broADCAST_PID");
tixmlText*text= newtixmlText("7215");
broadcast_Pid->SetAttribute("info","thepid");
broadcast_Pid->LinkEndChild(text);
broadcast->LinkEndChild(broadcast_Pid);

将在SOURCE_3后添加新的节点:
broADCAST_PID ="thepid" >7215 broADCAST_PID 四,最后说一下中文乱码的问题

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

len=WideCharToMultiByte(CP_ACP,NULL);
char*szGBK=newchar[len+1];
memset(szGBK,len+1);
WideCharToMultiByte(CP_ACP,szGBK,len,NULL);

strUtf8=szGBK;
delete[]szGBK;
delete[]wszGBK;
}



voidConvertGBKToUtf8(CString&strGBK)
{
intlen=MultiBytetoWideChar(CP_ACP,(LPCTSTR)strGBK,255)">short
*wszUtf8=short[len+1];
memset(wszUtf8,len*2+2);
MultiBytetoWideChar(CP_ACP,wszUtf8,len);

len=WideCharToMultiByte(CP_UTF8,255)">char*szUtf8=char[len+1];
memset(szUtf8,len+1);
WideCharToMultiByte(CP_UTF8,szUtf8,NULL);

strGBK=szUtf8;
delete[]szUtf8;
delete[]wszUtf8;
}

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

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

相关推荐


php输出xml格式字符串
J2ME Mobile 3D入门教程系列文章之一
XML轻松学习手册
XML入门的常见问题(一)
XML入门的常见问题(三)
XML轻松学习手册(2)XML概念
xml文件介绍及使用
xml编程(一)-xml语法
XML文件结构和基本语法
第2章 包装类
XML入门的常见问题(二)
Java对象的强、软、弱和虚引用
JS解析XML文件和XML字符串详解
java中枚举的详细使用介绍
了解Xml格式
XML入门的常见问题(四)
深入SQLite多线程的使用总结详解
PlayFramework完整实现一个APP(一)
XML和YAML的使用方法
XML轻松学习总节篇