• <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>
            Cpper
            C/C++高級工程師 Android高級軟件工程師 IT集成工程師 音頻工程師 熟悉c,c++,java,c#,py,js,asp等多種語言 程序猿
            接上篇
            本文主要涉及rapidxml讀文件的操作

            基本的步驟為
            首先獲取xml文件數(shù)據(jù)
            然后分析數(shù)據(jù)
            獲取節(jié)點
            獲取屬性
            獲取名字
            獲取值
            ...

            代碼如下:
            #include <iostream>
            #include 
            <rapidxml/rapidxml.hpp>
            #include 
            <rapidxml/rapidxml_utils.hpp>
            #include 
            <rapidxml/rapidxml_print.hpp>
             
            using namespace rapidxml;

            int main()
            {    
                 file
            <> fdoc("config.xml");
                 std::cout
            <<fdoc.data()<<std::endl; 
                 xml_document
            <>  doc;    
                 doc.parse
            <0>(fdoc.data()); 

                 std::cout
            <<doc.name()<<std::endl;
                 
                 
            //! 獲取根節(jié)點
                 xml_node<>* root = doc.first_node();
                 std::cout
            <<root->name()<<std::endl;

                 
            //! 獲取根節(jié)點第一個節(jié)點
                 xml_node<>* node1 = root->first_node();
                 std::cout
            <<node1->name()<<std::endl; 

                 xml_node
            <>* node11 = node1->first_node();
                 std::cout
            <<node11->name()<<std::endl;
                 std::cout
            <<node11->value()<<std::endl;
                 
                 
            //! 修改之后再次保存
                 xml_node<>* size = root->first_node("size");
                 size
            ->append_node(doc.allocate_node(node_element,"w","0"));
                 size
            ->append_node(doc.allocate_node(node_element,"h","0"));

                 std::
            string text;  
                 rapidxml::print(std::back_inserter(text),doc,
            0);  
             
                 std::cout
            <<text<<std::endl; 
                
                 std::ofstream 
            out("config.xml");
                 
            out << doc;

                 system(
            "PAUSE");
                 
            return EXIT_SUCCESS;
            }


            生成的xml為:
            <?xml version='1.0' encoding='utf-8' ?>
            <config>
                
            <color>
                    
            <red>0.1</red>
                    
            <green>0.1</green>
                    
            <blue>0.1</blue>
                    
            <alpha>1.0</alpha>
                
            </color>
                
            <size>
                    
            <x>640</x>
                    
            <y>480</y>
                
            </size>
                
            <mode fullscreen="false">screen mode</mode>
            </config>
            需要說明的是rapidxml明顯有一個bug
            那就是append_node(doc.allocate_node(node_element,"h","0"));的時候并不考慮該對象是否存在!

            經(jīng)過這2篇 基本上就可以使用xml了
            當(dāng)然這里并沒有涉及異常處理
            posted on 2010-04-16 21:49 ccsdu2009 閱讀(2443) 評論(0)  編輯 收藏 引用

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


             
            久久久久人妻一区精品果冻| 精品综合久久久久久97| 99久久777色| 精品久久久久久国产三级| 久久精品国产一区二区| 久久人人爽人人爽人人爽| 久久影院综合精品| 久久99精品久久久久久噜噜| 人妻无码精品久久亚瑟影视 | 久久99亚洲网美利坚合众国| 久久99精品久久久久久动态图| 狠狠综合久久综合中文88| 人人狠狠综合久久88成人| 精品乱码久久久久久夜夜嗨 | 亚洲精品国产字幕久久不卡 | 国产69精品久久久久观看软件 | 成人免费网站久久久| 女同久久| 91久久精品国产91性色也| 亚洲中文久久精品无码ww16 | 久久精品午夜一区二区福利| 蜜桃麻豆www久久国产精品| 国产Av激情久久无码天堂| 久久婷婷五月综合97色直播| 国产视频久久| 大香网伊人久久综合网2020| 久久香蕉国产线看观看精品yw| 思思久久99热免费精品6| 久久嫩草影院免费看夜色| 久久久久夜夜夜精品国产| 99久久精品免费看国产一区二区三区| 久久精品免费一区二区| 污污内射久久一区二区欧美日韩| 99久久综合狠狠综合久久| 久久夜色精品国产亚洲av| 久久婷婷五月综合色奶水99啪| 久久精品国产亚洲麻豆| 久久久中文字幕日本| 99精品久久精品| 亚洲嫩草影院久久精品| 亚洲精品蜜桃久久久久久|