TinyXML 库解析XML

前端之家收集整理的这篇文章主要介绍了TinyXML 库解析XML前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

网上的文章乱七八糟的,还不如官方的一个例子:http://sourceforge.net/projects/tinyxml/files/?source=navbar

一个解析xml字符串的接口:

  1. /*循环获取某段xml中某个子标签的若干个子标签中的值*/
  2.  
  3. bool GetPicUrls(const char* pContent,std::list<string>& pic_url_list)
  4. {
  5. TiXmlDocument doc( "demotest.xml" );
  6. doc.Parse( pContent );
  7. if ( doc.Error() )
  8. {
  9. printf( "Error in %s: %s\n",doc.Value(),doc.ErrorDesc() );
  10. return false;
  11. }
  12. doc.SaveFile();
  13.  
  14. //TiXmlDocument doc( "demotest.xml" );
  15. bool loadOkay = doc.LoadFile();
  16.  
  17. if ( !loadOkay )
  18. {
  19. printf( "Could not load test file 'demotest.xml'. Error='%s'. Exiting.\n",doc.ErrorDesc() );
  20. return false;
  21. }
  22.  
  23. TiXmlNode* node = 0;
  24. TiXmlNode* childNode = 0;
  25. TiXmlNode* childNodeUrl = 0;
  26. TiXmlElement* todoElement = 0;
  27. //TiXmlElement* itemElement = 0;
  28.  
  29. node = doc.FirstChild( "AAAAA" );//母节点
  30. if (node)
  31. {
  32. node = node->FirstChild("BBBBB");
  33. if (node)
  34. {
  35. node = node->FirstChild("CCCCC");//找到要循环遍历的子节点的母节点
  36. }
  37. }
  38. if (node)
  39. {
  40. childNode = node->FirstChild("xxxx");//找到第一个xxxx节点
  41. while (childNode)
  42. {
  43. childNodeUrl = childNode->FirstChild("xx");
  44. string strUrl;
  45. todoElement = childNodeUrl->ToElement();//转化成标签处理
  46. strUrl = todoElement->GetText();//获取标签的值
  47. pic_url_list.push_back(strUrl);
  48. const TiXmlNode* prevIoUsNode = childNode;
  49. childNode = node->IterateChildren("xxxx",prevIoUsNode);//下一个xxxx节点
  50. }
  51. }
  52.  
  53. return true;
  54. }
  55.  

上面的代码中保存本地文档的步骤可注释掉。基本的思想是先将整个xml当做一个dom,然后寻找到需要的节点,然后将其转化成标签处理。当然在找到某个节点的位置后,还可以进行插入节点等操作。

猜你在找的XML相关文章