使用xmlDocument.SelectNodes(String xpath) 是很方便的方法, 可是寫XPath 卻要費(fèi)點(diǎn)功夫,
今天發(fā)現(xiàn)XPath1.0里沒(méi)有 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é)點(diǎn)值為GEN(case-insensitive)的AAA節(jié)點(diǎn), 如果沒(méi)有后面的Xpath, 要做到以上查詢, 挺復(fù)雜, 如果會(huì)用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é)點(diǎn)的value 全部變成大寫, 然后和'GEN'比較, 然后返回AAA節(jié)點(diǎn).
http://www.survivalescaperooms.com/happyy2k/archive/2006/10/31/545128.html
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注