linux c++ TinyXML操做

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以下:
<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的一些操做。

本文出自 「C++技術」 博客,請務必保留此出處http://panpan.blog.51cto.com/489034/104961ios

相關文章
相關標籤/搜索