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字符流了,這是不少開發者不太熟悉的狀況。
測試