使用xmldocument.selectnodes(string xpath) 是很方便的方法, 可是寫xpath 卻要費點功夫,
今天發(fā)現(xiàn)xpath1.0里沒有 case-insensitive 的 function 所以很難做下面的查詢
<root>
<aaa>
<bbb>
<ccc>ddd</ccc>
<bbb>
<ccc> gen</ccc> //也可能是gen, gen, gen
</bbb>
</aaa>
<aaa>
<bbb>
<ccc>dfe</ccc>
<bbb>
<ccc> gen</ccc>
</bbb>
</aaa
</root>
查找所有的ccc節(jié)點值為gen(case-insensitive)的aaa節(jié)點, 如果沒有后面的xpath, 要做到以上查詢, 挺復(fù)雜, 如果會用xpath 的 translate function, 就很容易了
xpath = @"http://root/aaa/bbb/[translate(ccc, 'abcdefghijklmnopqrstuvwxyz', 'abcdefghijklmnopqrstuvwxyz')] = 'gen'/parent::*"
xmlnodelist nodelist = xmldoc.selectnodes(xpath);
xpath的意思是, 把//root/aaa/bbb/ccc節(jié)點的value 全部變成大寫, 然后和'gen'比較, 然后返回aaa節(jié)點.
新聞熱點
疑難解答
圖片精選