• <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>

            牽著老婆滿街逛

            嚴以律己,寬以待人. 三思而后行.
            GMail/GTalk: yanglinbo#google.com;
            MSN/Email: tx7do#yahoo.com.cn;
            QQ: 3 0 3 3 9 6 9 2 0 .

            有關TinyXML使用的簡單總結

            from:http://www.cnblogs.com/freecoder/archive/2006/08/07/tinyxmlstaplea.html

               這次使用了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的使用作了介紹,歡迎各位提問留言,我會盡力解答各位的問題

            posted on 2007-05-15 18:12 楊粼波 閱讀(603) 評論(2)  編輯 收藏 引用

            評論

            # re: 有關TinyXML使用的簡單總結 2007-08-14 15:22 flying_bat

            寫的不錯呀。  回復  更多評論   

            # re: 有關TinyXML使用的簡單總結 2007-08-15 00:40 楊粼波

            恩,的確是寫得不錯,
            很淺顯易懂,
            如此我才保存了下來的。
            今天看了Tinyxml的源碼,
            感覺結構有點復雜,
            一時間也沒有太理解,
            還要努力學習啊。  回復  更多評論   

            亚洲欧洲久久久精品| 久久婷婷五月综合97色一本一本| 91久久成人免费| 久久性精品| 亚洲香蕉网久久综合影视| 国产精品久久永久免费| 久久av高潮av无码av喷吹| 97久久婷婷五月综合色d啪蜜芽| 久久综合国产乱子伦精品免费| 国产精品久久久久乳精品爆| 久久人人爽人人人人爽AV| 亚洲伊人久久大香线蕉苏妲己| 久久久久久精品久久久久| 国内精品久久久久久麻豆| 99久久er这里只有精品18| 精品国产VA久久久久久久冰| 91麻豆精品国产91久久久久久| 一本久久免费视频| 亚洲国产天堂久久综合网站| 少妇久久久久久久久久| 久久九九久精品国产| 99精品国产在热久久无毒不卡| 精品国产日韩久久亚洲| 久久精品?ⅴ无码中文字幕| 99久久免费国产精精品| 亚洲欧洲日产国码无码久久99| 亚洲精品乱码久久久久久蜜桃| 国产精品九九久久精品女同亚洲欧美日韩综合区| 久久青青草视频| 亚洲欧洲精品成人久久奇米网| 久久青青国产| 久久WWW免费人成—看片| 国产精品免费看久久久香蕉| 久久久中文字幕| 狠狠人妻久久久久久综合蜜桃| 2020最新久久久视精品爱| 久久青青草原综合伊人| 香蕉久久一区二区不卡无毒影院| 久久99精品国产一区二区三区| www.久久99| 亚洲国产成人精品91久久久 |