TinyXML 库解析XML

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

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

/*循环获取某段xml中某个子标签的若干个子标签中的值*/

bool GetPicUrls(const char* pContent, std::list<string>& pic_url_list)
{
 TiXmlDocument doc( "demotest.xml" );
 doc.Parse( pContent );
 if ( doc.Error() )
 {
  printf( "Error in %s: %s\n", doc.Value(), doc.ErrorDesc() );
  return false;
 }
 doc.SaveFile();

 //TiXmlDocument doc( "demotest.xml" );
 bool loadOkay = doc.LoadFile();

 if ( !loadOkay )
 {
  printf( "Could not load test file 'demotest.xml'. Error='%s'. Exiting.\n", doc.ErrorDesc() );
  return false;
 }

 TiXmlNode* node = 0;
 TiXmlNode* childNode = 0;
 TiXmlNode* childNodeUrl = 0;
 TiXmlElement* todoElement = 0;
 //TiXmlElement* itemElement = 0;

 node = doc.FirstChild( "AAAAA" );//母节点
 if (node)
 {
  node = node->FirstChild("BBBBB");
  if (node)
  {
   node = node->FirstChild("CCCCC");//找到要循环遍历的子节点的母节点
  }
 }
 
 if (node)
 {
  childNode = node->FirstChild("xxxx");//找到第一个xxxx节点
  while (childNode)
  {
   childNodeUrl = childNode->FirstChild("xx");
   string strUrl;
   todoElement = childNodeUrl->ToElement();//转化成标签处理
   strUrl = todoElement->GetText();//获取标签的值
   pic_url_list.push_back(strUrl);
   const TiXmlNode* previousNode = childNode;
   childNode = node->IterateChildren("xxxx", previousNode);//下一个xxxx节点
  }
 }

 return true;
}

 

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值