最 近使用TinyXML進行C++ XML解析,感受使用起來比較簡單,很容易上手,本文給出一個使用TinyXML進行XML解析的簡單例子,不少複雜的應用均可以基於本例子的方法來完 成。之後的文章裏會講解使用Xerces進行C++ XML解析的例子,但願你們一塊兒交流。
TinyXML是一個開源的解析XML的解析庫,可以用於C++,可以在Windows或Linux中編譯。這個解析庫的模型經過解析XML文件,而後在內存中生成DOM模型,從而讓咱們很方便的遍歷這棵XML樹。
DOM模型即文檔對象模型,是將整個文檔分紅多個元素(如書、章、節、段等),並利用樹型結構表示這些元素之間的順序關係以及嵌套包含關係。
首先從網上下載TinyXML的庫,文件夾的名字是TinyXpath,在工程裏作以下配置:
在附加包含路徑裏添加:你的tinyxpath路徑/tinyxpath/include
在附加庫路徑裏添加:你的tinyxpath路徑/tinyxpath/lib
在對象/庫路徑裏添加:tinyxpathd.lib,若是使用release版本,則是tinyxpath.lib。
另外,因爲我開發的項目是多線程的,因此設置了多線程的環境,所以使用TinyXML沒有出現問題。本人將TinyXML寫在一個單獨的C++工程進行測試,發現若是不設置多線程的環境,會出現連接錯誤。我以爲緣由多是TinyXML使用了多線程環境,所以須要設置多線程的環境。在工程/設置下的C/C++選項卡中,選擇Code Generation,在Use run-time library中選擇Debug MultiThreaed DLL便可。
本例的XML文件Students.xml以下:ios
<Class name=
"計算機軟件班">
<Students>
<student name=
"張三" studentNo=
"13031001" sex=
"男" age=
"22">
<phone>88208888</phone>
<address>西安市太白南路二號</address>
</student>
<student name=
"李四" studentNo=
"13031002" sex=
"男" age=
"20">
<phone>88206666</phone>
<address>西安市光華路</address>
</student>
</Students>
</Class>
程序代碼XmlParseExample.cpp以下所示:多線程
#include <iostream>
#include <
string>
#include <tinyxml.h>
using std::
string;
int main()
{
TiXmlDocument* myDocument =
new TiXmlDocument();
myDocument->LoadFile(
"Students.xml");
TiXmlElement* rootElement = myDocument->RootElement();
//Class
TiXmlElement* studentsElement = rootElement->FirstChildElement();
//Students
TiXmlElement* studentElement = studentsElement->FirstChildElement();
//Students
while ( studentElement ) {
TiXmlAttribute* attributeOfStudent = studentElement->FirstAttribute();
//得到student的name屬性
while ( attributeOfStudent ) {
std::cout << attributeOfStudent->Name() <<
" : " << attributeOfStudent->Value() << std::endl;
attributeOfStudent = attributeOfStudent->Next();
}
TiXmlElement* phoneElement = studentElement->FirstChildElement();
//得到student的phone元素
std::cout <<
"phone" <<
" : " << phoneElement->GetText() << std::endl;
TiXmlElement* addressElement = phoneElement->NextSiblingElement();
std::cout <<
"address" <<
" : " << phoneElement->GetText() << std::endl;
studentElement = studentElement->NextSiblingElement();
}
return 0;
}
程序運行結果以下:
name : 張三
studentNo : 13031001
sex : 男
age : 22
phone : 88208888
address : 88208888
name : 李四
studentNo : 13031002
sex : 男
age : 20
phone : 88206666
address : 88206666
本例中使用的是對xml文件進行解析,很容易掌握,可是不少開發人員不知道如何對xml 字符流(非xml文件)進行解析,我看了TinyXML提供的源代碼,裏面可使用以下方法對xml流解析。對應於上例,代碼以下:函數
string xmlString =
"<Class name=\"計算機軟件班\">\
<Students>\
<student name=\"張三\" studentNo=\"13031001\" sex=\"男\" age=\"22\">\
<phone>88208888</phone>\
<address>西安市太白南路二號</address>\
</student>\
<student name=\"李四\" studentNo=\"13031002\" sex=\"男\" age=\"20\">\
<phone>88206666</phone>\
<address>西安市光華路</address>\
</student>\
</Students>\
</Class>";
TiXmlDocument* myDocument =
new TiXmlDocument();
myDocument->Parse(xmlString.c_str());
使用Parse函數就能夠解析XML字符流了,這是不少開發者不太熟悉的狀況。
測試
若是開發者開發特定應用,就可使用上述相似方法,可能不須要徹底處理每個屬性,好比能夠對屬性名進行判斷,只處理本身須要的屬性,或者本身須要的 xml元素。還可使用TinyXML的方法建立xml元素和xml屬性,或者設置xml元素和屬性對應的值,等等,若是讀者想要相似的例子,能夠留言寫 出。
下面介紹TinyXML的一些類。在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的一些操做。