参考:
http://stackoverflow.com/questions/21029167/rapidxml-giving-empty-cdata-nodes
http://blog.csdn.net/luojiaoqq/article/details/8746685
这几天用RapidXML解析xml文件,解析到有CDATA类型的数据时,value死活解析不出来,为空。
情况如下面所示:
<yourname><![CDATA[luojiao]]></yourname>
用如下语句解析:
pNode->first_node("yourname")->value()
总是为空,无法解析出“luojiao”。
后来通过RapidXML本身的print函数单步跟踪,发现它是这么用的:
pNode->first_node("yourname")->first_node()->value()
我也按这个方式解析,就成功解析出“luojiao“ 字符串。
RapidXML很奇怪的一点,对普通的节点,值就是值,直接就value()函数就取出了。而CDATA类型的节点,却认为这个CDATA是一个child,需要继续向下一层才能取出值。
【yasi】
StackOverflow的帖子 指出,Rapidxml 是这样对待一个带有CDATA的节点的:
将当前节点的CDATA数据作为当前节点“下面”的一个子节点。如果要取当前节点的CDATA数据,必须再往下一层,即先去当前节点的子节点,然后再对这个子节点取value