微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

tinyxml解析xml文件

一、tinyxml 库

tinyxml 开源精简版本xml 解析库,相比于libxml2 更适合使用于嵌入式设备当中xml数据的解析和构造


tixmlBase Class Reference




下载TinyXML的网址:

http://www.grinninglizard.com/tinyxml/


二、tinyxml 编译成.so

1、将tinyxml 拷贝到/home/work/目录下

cptinyxml /home/work/tinyxml

cd/home/work/tinyxml/


2、修改Makefile

vim Makefile


28 DEBUG_CFLAGS := -Wall -Wno-format -g -DDEBUG -fpic -shared # 添加-fpic -shared 生成动态库参数
29 RELEASE_CFLAGS := -Wall -Wno-unkNown-pragmas -Wno-format -O3 -fpic -shared# 添加-fpic -shared生成动态库参数


84 OUTPUT := libtinyxml.so # 设置输出lib库


93 SRCS := tinyxml.cpp tinyxmlparser.cpp tinyxmlerror.cpp tinystr.cpp # 删掉原本编译进去的xmltest.cpp


105 ${LD} -o $@ ${LDFLAGS} ${OBJS} ${LIBS} ${EXTRA_LIBS} ${CXXFLAGS} # 加入${CXXFLAGS} 参数,输出最终lib库


3、编译生成libtinyxml.so

make


4、交叉编译移植tinyxml 到开发板,需要修改

22 CC := arm-linux-gcc
23 CXX := arm-linux-g++
24 LD := arm-linux-g++
25 AR := arm-linux-ar rc


三、编写测试例子

1、解析xml 数据<xxxxx>data</xxxxxx> 形式存放的xml数据

test.xml 内容如下:

<?xml version="1.0" encoding="UTF-8"?>
<Message xmlns="http://mns.aliyuncs.com/doc/v1">
<MessageId>6D438C3EE5E6E031-1-1579E5A156F-20000000E</MessageId>
<MessageBodyMD5>009F8E6EDCA8CA12AB5F82F5EBE514F7</MessageBodyMD5>
<MessageBody>{"title":"text","content":"测试消息"}</MessageBody>
<ReceiptHandle>1-ODU4OTkzNDYwNi0xNDc1ODM0MjI3LTetoA==</ReceiptHandle>
<EnqueueTime>1475830486383</EnqueueTime>
<FirstDequeueTime>1475831421138</FirstDequeueTime>
<NextVisibleTime>1475834227000</NextVisibleTime>
<DequeueCount>2</DequeueCount>
<Priority>8</Priority>
</Message>


以上xml数据都是以 <xxxxx>data</xxxxxx> 形式存放的xml数据

对应的解析程序如下:


#include <stdio.h>
#include "tinyxml.h"


int test_xml(const char *xmlfile)
{
tixmlDocument* myDocument = new tixmlDocument();
myDocument->LoadFile(xmlfile);

tixmlElement* rootElement = myDocument->RootElement();

if (rootElement == NULL || strcmp(rootElement->Value(),"Message"))
return -1;
printf("%s:\t %s \n",rootElement->Value(),rootElement->GetText());

tixmlElement* element = rootElement->FirstChildElement();
if (element == NULL || strcmp(element->Value(),"MessageId"))
return -1;
printf("%s:\t %s \n",element->Value(),element->GetText());
while(1){
element = element->NextSiblingElement();
if(element == NULL){
break;
}
printf("%s:\t%s\n",element->GetText());
}

myDocument->Clear();

delete myDocument;
}
int main(int argc,char* argv[])
{

if(argc<2){

printf("input xml file\n");

return -1;

}
test_xml((const char *)argv[1]);
return 0;
}


2、解析item 类型的xml数据

xml数据格式如下:

<Todo>
<Item priority="1">
<bold>
Book store!
</bold>
</Item>
<Item priority="2">
book1
</Item>
<Item priority="2">
book2
</Item>
</Todo>


解析源码:

#include <stdio.h>
#include <iostream>
#include <string>


#include "tinyxml.h"


using namespace std;


int loadXML(const char *xmlfile)
{
tixmlDocument doc;
if(!doc.LoadFile(xmlfile)){
cerr << doc.ErrorDesc() << endl;
return FAILURE;
}


tixmlElement* root = doc.FirstChildElement();
if(root == NULL)
{
cerr << "Failed to load file: No root element." << endl;
doc.Clear();
return FAILURE;
}


for(tixmlElement* elem = root->FirstChildElement(); elem != NULL; elem = elem->NextSiblingElement())
{
string elemName = elem->Value();
const char* attr;
attr = elem->Attribute("priority");
printf("attr = %s\n",attr);
if(strcmp(attr,"1")==0)
{
tixmlElement* e1 = elem->FirstChildElement("bold");
tixmlNode* e2=e1->FirstChild();
cout<<"priority=1\t"<<e2->ToText()->Value()<<endl;


}
else if(strcmp(attr,"2")==0)
{
tixmlNode* e1 = elem->FirstChild();
cout<<"priority=2\t"<<e1->ToText()->Value()<<endl;
}

}
doc.Clear();
return 0;
}


int main(int argc,char* argv[])
{
if(argc<2){
printf("input xml file\n");
return -1;
}
if(loadXML(argv[1]))
return -1;
return 0;
}


3、生成xml数据

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <iostream>
#include "tinyxml.h"
using namespace std;
int saveXML(const char *file){
tixmlDocument doc;


tixmlElement* root = new tixmlElement("root");
doc.LinkEndChild(root);


tixmlElement* element1 = new tixmlElement("Element1");
root->LinkEndChild(element1);


element1->SetAttribute("attribute1","some value");


tixmlElement* element2 = new tixmlElement("Element2"); ///元素
root->LinkEndChild(element2);


element2->SetAttribute("attribute2","2");
element2->SetAttribute("attribute3","3");


tixmlElement* element3 = new tixmlElement("Element3");
element2->LinkEndChild(element3);


element3->SetAttribute("attribute4","4");


tixmlText* text = new tixmlText("Some text."); ///文本
element2->LinkEndChild(text);




bool success = doc.SaveFile((char *)file);
doc.Clear();


if(success)
return 0;
else
return -1;
}


int main(int argc,char* argv[]){
if(argc<2){

printf("input save file \n");
return -1;
}
if(saveXML((const char *)argv[1]))
return -1;
printf("save xml ok \n");
return 0;
}


生成的xml内容如下:

<root> <Element1 attribute1="some value" /> <Element2 attribute2="2" attribute3="3"> <Element3 attribute4="4" />Some text. </Element2> </root>

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