xml操作SelectNodes报错:表达式的计算结果必须为节点集

hh0702 2011-04-27 04:48:58
在执行 ReadResource("ConfigItemEdit", "yy-en.xml") 报错:
表达式的计算结果必须为节点集。

请帮看看错在哪里,谢谢!!!




public static Hashtable ReadResource(string frmName, string lang)
{
Hashtable result = new Hashtable();
XmlReader reader = null;
reader = new XmlTextReader(lang );

XmlDocument doc = new XmlDocument();
doc.Load(reader);

XmlNode root = doc.DocumentElement;
XmlNodeList nodelist = root.SelectNodes( "[Name=" + frmName + "]/Controls/Control");
//最后一句报错:表达式的计算结果必须为节点集。


foreach (XmlNode node in nodelist)
{
try
{
XmlNode node1 = node.SelectSingleNode("@name");
XmlNode node2 = node.SelectSingleNode("@text");
if (node1 != null)
{
result.Add(node1.InnerText.ToLower(), node2.InnerText);
}
}
catch (FormatException fe)
{
Console.WriteLine(fe.ToString());
}
}
reader.Close();
return result;
}






文件:yy-en.xml



<?xml version="1.0" encoding="utf-8" ?>
<Resource>
<Form>
<Name>ConfigItemEdit</Name>
<Controls>
<Control name="txtTtitle" text="Ttitle~" />
<Control name="txtTips" text="tipsssssssssssss:" />
<Control name="chkEnabledStatet" text="kq" />
</Controls>
</Form>

<Form>
<Name>FrmPasswordChange</Name>
<Controls>
<Control name="txtTtitle" text="Ttiasdfasdfa234234234234sdfasdftle~" />
<Control name="txtTips" text="tipsssssssssasdfasd34234234ssss:" />
<Control name="chkEnabledStatet" text="k23423423423423q" />
</Controls>
</Form>
</Resource>
...全文
1597 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
hh0702 2011-04-28
  • 打赏
  • 举报
回复
感谢 huangwenquan123 !

用你的方法搞定,用xml做多语言还是蛮方便~
huangwenquan123 2011-04-27
  • 打赏
  • 举报
回复
    public static Hashtable ReadResource(string fldname,string path)
{
Hashtable hs = new Hashtable();
XmlDocument xml = new XmlDocument();
xml.Load(path);
XmlNodeList node = xml.SelectSingleNode("//Name[text()='" + fldname + "']").NextSibling.SelectNodes("Control");
foreach (XmlNode n in node)
{
hs.Add(n.Attributes["name"].Value, n.Attributes["text"].Value);
}
return hs;
}
//调用
string path = Server.MapPath("XMLFile3.xml");
Hashtable hs = ReadResource("FrmPasswordChange", path);
foreach (DictionaryEntry d in hs)
{
Response.Write(d.Key + "===" + d.Value + "<br/>");
}
/*
txtTtitle===Ttiasdfasdfa234234234234sdfasdftle~
chkEnabledStatet===k23423423423423q
txtTips===tipsssssssssasdfasd34234234ssss:
*/
hh0702 2011-04-27
  • 打赏
  • 举报
回复
还是没解决

Icedmilk 能详细说说么
se7en 2011-04-27
  • 打赏
  • 举报
回复
肯定是xml文件对应的节点啊 。应该不能是整个xml文件吧
Icedmilk 2011-04-27
  • 打赏
  • 举报
回复
"/Resource/Form[Name = \"ConfigItemEdit\"]/Controls/Control"

XPath 这样写试试
hh0702 2011-04-27
  • 打赏
  • 举报
回复
自己顶一下,在线等待~
1.XML 1.1. 概念:XML(eXtensible Markup Language),是一种可扩展的标记语言 1.2. 作用: XML是跨平台和跨语言的 不同的语言都支持XML解析(将XML转换为对应语言中的数据) 1. 数据交换格式(一般不用了,用json代替了) 2. 配置文件都使用XML格式,框架都是用xml和Properties作为配置文件。 1.3. 使用:(掌握) 语法: xml version="1.0" encoding="UTF-8"?> XML的语法格式: 第一行用了定义xml文件的,写版本号和字符 1.注释不能放到第一行 1.必需有声明,声明必需在第一行。 2.文档声明的字符编码必需和文档本身的编码一致 2.标签不能交叉嵌套使用(标签名字随便定义) 1. 双标签 : <双标签>一般是有下一级的 2. 单标签 :<单标签/> 如果没有下一级,就可以用单标签 3.有开始有结束 4.不数字开头,只能以字母或下划线开头; 5.只能有一个根标签;表示不能再有其他平级标签 6.严格区分大小写 7.一个标签不能有两个相同属性(属性名随便定义) 属性直接写在头标签内,格式:属性名="属性值" 8.特殊符号需要转义 或者可以放到CDATA区 html特殊符号,转义符号 9.编码格式统一: 1.开发环境:项目环境、系统环境 2.当前文件内encoding字符 10.不能以xml(或者XMLXml等)开头W3C保留日后使用; 例如:最好不要使用 <xml:xx>xml: xx>W3C保留以后在使用 11.名称字符之间不能有空格或者制表符; 例如<四川 省> 12.名称字符之间不能使用冒号;<xml:xx>xml: xx> 注意: 1.Xml中空格和换行都表示数据,严格区分大小写 1.4 XML约束:(了解) 1. 概念:就是限制一个XML文件中标签和属性等的使用,只能按照某种规则书写 便于其他程序员学习。 2. 作用: 1. 代码校验 2. 代码提示 3. 利于达成共识形成规范 3. 约束分类: 1. DTD约束:Document Type Definition文档类型定义 例如: 2. schema约束:xml Schema Definition xsd文件 例如: xml version="1.0" encoding="UTF-8" ?> xmlns:xs="http://www.w3.org/2001/XMLSchema" targetNamespace="http://itsource.cn" elementFormDefault="qualified"> 1.5. XML解析(最重要) DOM: 文档对象模型 将一个XML(html)文档 的每一个元素解析成java中的一个一个的对象 D Document 文档(XML文档) : 磁盘上面的xml文件 O Object 对象(Java对象) : 把xml文件封装成Java对象 M Model 模型 解析过程中用到的类: Document Node(节点) Element (元素) Attribute(属性) - Attr Text(文本) dom4j解析: 支持xpath解析,就可以可以直接输入一个路径查找: 由于DOM4J在解析XML时只能一层一层解析,所以当XML文件层数过多时使用会很不方便, 结合XPATH就可以直接获取到某个元素 使用dom4j支持xpath的操作的几种主要形式   第一种形式     /a/b/c: 表示一层一层的,a下面 b下面的c   第二种形式      //b: 表示和这个名称相同,表示只要名称是b,都得到 第三种形式     /* : 所有元素 第四种形式     a[1]: 表示第一个a元素     a[last()]:表示最后一个a元素 第五种形式     //a[@id]: 表示只要a元素上面有id属性,都得到 第六种形式     //a[@id='b1'] 表示元素名称是a,在a上面有id属性,并且id的属性值是b1 使用dom4j支持xpath具体操作 默认的情况下,dom4j不支持xpath,如果想要在dom4j里面是有xpath, 第一步需要,引入支持xpath的jar包,如下: jaxen-1.1-beta-6.jar 在dom4j里面提供了两个方法,用来支持xpath     selectNodes("xpath表达式"),获取多个节点        selectSingleNode("xpath表达式"),获取一个节点 步骤: 1. 在项目下创建一个lib文件夹folder 2. 复制dom4j的jar包到lib文件夹中 3. 选中jar右键buildpath 4. 在测试类中使用dom4j解析XML。(今天开始学习别人的api) dom4j中使用到的方法: 1.创建SaxReader对象 SAXReader reader = new SAXReader(); 2.设置命名空间 reader.getDocumentFactory().setXPathNamespaceURIs(map); 3. SAXReader对象调用read方法,将当前XML文件,转换为Document对象 document = reader.read(file); 4. 获取根节点 root = document.getRootElement(); 5. 通过父签添加子标签(元素) Element element = root.addElement("标签名");//返回值就是要添加的元素对象 给子标签添加值 element.setText("标签值"); 6. 给当前标签添加属性:xxx ,值是:xxx Element attribute = linkman.addAttribute("属性名","值"); 通过属性对象attribute获取属性值 attribute.setText("值"); 通过属性对象attribute获取属性值 String 值 = attribute.getText(); 7. 获取当前元素标签名 String name = e.getName(); 获取当前元素标签值 String text = e.getText(); 8. 获取指定名字的子标签(元素) root.element(String name); 9. 获取所有子标签(元素) root.elements(); 10.在dom4j里面提供了两个方法,用来支持xpath      selectNodes("xpath表达式"),获取当前名字的多个节点 selectSingleNode("xpath表达式"),获取一个节点

110,539

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧