• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            網絡服務器軟件開發/中間件開發,關注ACE/ICE/boost

            C++博客 首頁 新隨筆 聯系 聚合 管理
              152 Posts :: 3 Stories :: 172 Comments :: 0 Trackbacks
            轉貼-有關TinyXML使用的簡單總結
            floodking 發表于 2006-11-6 18:01:00

             這次使用了TinyXML后,覺得這個東西真是不錯,于是將使用方法坐下總結來和大家分享。
                該解析庫在開源網站(http://sourceforge.net )上有下載,在本Blog也提供下載(下載TinyXML
                TinyXML是一個開源的解析XML的解析庫,能夠用于C++,能夠在WindowsLinux中編譯。這個解析庫的模型通過解析XML文件,然后在內存中生成DOM模型,從而讓我們很方便的遍歷這課XML樹。
                注:DOM模型即文檔對象模型,是將整個文檔分成多個元素(如書、章、節、段等),并利用樹型結構表示這些元素之間的順序關系以及嵌套包含關系(理解html語言的讀者會很容易理解這種樹狀模型)。               
                如下是一個XML片段:
                <Persons>
                    <Person ID="1">
                        <name>周星星</name>
                        <age>20</age>
                    </Person>
                    <Person ID="2">
                        <name>白晶晶</name>
                        <age>18</age>
                    </Person>
                </Persons>
                在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的一些操作。
                那我們如何使用這些類以及他們的方法來操縱我們的XML呢?請看下面。
                一、讀取XML(假設我們的Xml文檔中的內容與上面的Xml內容一樣)
                //創建一個XML的文檔對象
                TiXmlDocument *myDocument = new TiXmlDocument("填上你的Xml文件名");
                myDocument->LoadFile();
                //獲得根元素,即Persons。
                TiXmlElement *RootElement = myDocument.RootElement();
                //輸出根元素名稱,即輸出Persons。
                cout << RootElement->Value() << endl;
                //獲得第一個Person節點。
                TiXmlElement *FirstPerson = RootElement->FirstChildElement();
                //獲得第一個Person的name節點和age節點和ID屬性。
                TiXmlElement *NameElement = FirstPerson->FirstChildElement();
                TiXmlElement *AgeElement = NameElement->NextSiblingElement();
                TiXmlAttribute *IDAttribute = FirstPerson->FirstAttribute();
                //輸出第一個Person的name內容,即周星星;age內容,即20;ID屬性,即1。
                cout << NameElement->FirstChild()->Value << endl;
                cout << AgeElement->FirstChild()->Value << endl;
                cout << IDAttribute->Value() << endl;

                
                看,讀取XML是不是很簡單阿,和Java的XML解析庫非常的相似,就是名字改了一下而已。
                二、生成XML內容
                //創建一個XML的文檔對象。
                TiXmlDocument *myDocument = new TiXmlDocument();
                //創建一個根元素并連接。
                TiXmlElement *RootElement = new TiXmlElement("Persons");
                myDocument->LinkEndChild(RootElement);
                //創建一個Person元素并連接。
                TiXmlElement *PersonElement = new TiXmlElement("Person");
                RootElement->LinkEndChild(PersonElement);
                //設置Person元素的屬性。
                PersonElement->SetAttribute("ID", "1");
                //創建name元素、age元素并連接。
                TiXmlElement *NameElement = new TiXmlElement("name");
                TiXmlElement *AgeElement = new TiXmlElement("age");
                PersonElement->LinkEndChild(NameElement);
                PersonElement->LinkEndChild(AgeElement);
                //設置name元素和age元素的內容并連接。
                TiXmlText *NameContent = new TiXmlText("周星星");
                TiXmlText *AgeContent = new TiXmlText("20");
                NameElement->LinkEndChild(NameContent);
                AgeElement->LinkEndChild(AgeContent);
                //保存到文件
                myDocument->SaveFile("要保存的xml文件名");
                這樣,便創建了一個如下的xml文件:
                <Persons>
                    <Person ID="1">
                        <name>周星星</name>
                        <age>20</age>
                    </Person>
                </Persons>
                
                是不是很簡單啊?在這里我只是簡單的對TinyXml的使用作了介紹,歡迎各位提問留言,我會盡力解答各位的問題。[By Lqbest]
            posted on 2007-04-03 09:28 true 閱讀(915) 評論(0)  編輯 收藏 引用 所屬分類: 其它開源庫
            亚洲午夜福利精品久久| 欧美丰满熟妇BBB久久久| 久久精品国产亚洲AV不卡| 久久国产精品免费一区| 久久狠狠爱亚洲综合影院| 91精品国产高清91久久久久久| 亚洲国产成人久久综合碰碰动漫3d| 久久亚洲国产成人影院网站| 99久久国产宗和精品1上映| 草草久久久无码国产专区| 久久精品国产亚洲αv忘忧草| 久久91精品久久91综合| 久久久久久国产a免费观看黄色大片 | 久久综合九色欧美综合狠狠| 午夜精品久久久久| 久久青青草原国产精品免费| 亚洲人成无码www久久久| 国产综合久久久久久鬼色| 婷婷久久五月天| 亚洲国产精品人久久| 亚洲中文字幕久久精品无码喷水| 97精品伊人久久久大香线蕉 | 久久精品国产亚洲AV香蕉| 欧美激情精品久久久久久久九九九 | 国产成人精品综合久久久| 久久综合九色欧美综合狠狠| 日本免费一区二区久久人人澡| 99久久99久久精品国产片果冻| 精品国产青草久久久久福利| 2021久久精品国产99国产精品| 国产激情久久久久久熟女老人| 狠狠色伊人久久精品综合网 | 精品久久久无码人妻中文字幕豆芽| 久久午夜综合久久| 久久久久四虎国产精品| 91视频国产91久久久| 亚洲国产一成人久久精品| 欧美日韩精品久久久久| 日本WV一本一道久久香蕉| 久久天天躁夜夜躁狠狠| 国产69精品久久久久观看软件 |