使用XmlDocument.SelectNodes(String xpath)是很方便的方法,只不过写XPath却要费点功夫,
今天发现XPath1.0里没有不区分大小写的函数所以很难做下面的查询
<root>
<AAA>
<BBB>
<CCC>ddd</CCC>
<BBB>
<CCC> GEN</CCC> //也可能是Gen, gen, GEn
</BBB>
</AAA>
<AAA>
<BBB>
<CCC>DFE</CCC>
<BBB>
<CCC>根</CCC>
</BBB>
</AAA
</root>
查找所有的CCC节点值为GEN(不区分大小写)的AAA节点,如果没有后面的Xpath,要实现以上查询,挺复杂,如果会用Xpath的translate函数,就很容易了
xpath = @"//root/AAA/BBB/[翻译(CCC, 'abcdefghijklmnopqrstuvwxyz', 'ABCDEFGHIJKLMNOPQRSTUVWXYZ')] = 'GEN'/parent::*"
XmlNodeList 节点列表 = xmlDoc.SelectNodes(xpath);
xpath的意思是,把//root/AAA/BBB/CCC节点的值全部变成大写,然后和'GEN'比较,然后返回AAA节点。
http://www.cnblogs.com/happyy2k/archive/2006/10/31/545128.html