C#读取XML节点数据:XPath与遍历方式
93 浏览量
更新于2024-08-29
收藏 51KB PDF 举报
"C#读取XML节点数据方法小结"
在C#编程中,XML文件是一种常见的数据存储格式,用于传递和存储结构化数据。本文将介绍两种在C#中读取XML节点数据的方法:使用XPath和遍历式读取。
### 第一种:使用XPath
XPath(XML Path Language)是一种在XML文档中查找信息的语言。它允许通过表达式来选取节点,如元素、属性、文本等。在以下示例中,我们将XML文件的路径配置在`web.config`的`appSettings`节点下,并通过XPath选取`Organization`节点。
```csharp
// 加载XML文件
string orgCodePath = Server.MapPath(ConfigurationManager.AppSettings["orgCodePath"]);
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load(orgCodePath);
// 使用XPath选取所有Organization节点
XmlNodeList topM = xmlDoc.SelectNodes("//Organization");
// 遍历选取的节点并存储数据
Hashtable ht = new Hashtable();
foreach (XmlElement element in topM)
{
string id = element.GetElementsByTagName("ID")[0].InnerText;
string domainName = element.GetElementsByTagName("DomainName")[0].InnerText;
ht.Add(id, domainName);
}
```
在这个例子中,我们首先加载XML文件,然后使用`SelectNodes`方法与XPath表达式`//Organization`来选取所有的`Organization`节点。接着,遍历选取的节点,提取`ID`和`DomainName`子节点的文本内容,并存储到`HashTable`中。
### 第二种:遍历式读取XML
除了使用XPath,还可以通过遍历XML文档的节点树来读取数据。这种方法适用于不熟悉XPath或者需要更多控制的情况。
```csharp
// 打开XML文件
string filename = Server.MapPath(@"~\path\to\your\xmlfile.xml");
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load(filename);
// 获取根节点
XmlNode rootNode = xmlDoc.DocumentElement;
// 遍历XML树
foreach (XmlNode node in rootNode.ChildNodes)
{
if (node.NodeType == XmlNodeType.Element && node.Name == "Organization")
{
string id = node.SelectSingleNode("ID").InnerText;
string domainName = node.SelectSingleNode("DomainName").InnerText;
// 存储数据到自定义数据结构
// ...
}
}
```
在这个遍历式方法中,我们首先加载XML文件,获取根节点,然后遍历根节点的所有子节点。当遇到名为`Organization`的元素节点时,我们进一步选取`ID`和`DomainName`子节点的文本内容。
这两种方法都可以有效地读取XML文件中的数据,选择哪种取决于个人偏好、项目需求以及对XPath的熟悉程度。XPath提供了更简洁的表达方式,而遍历则更加直观且易于理解。在实际开发中,开发者可以根据具体情况灵活选用。
2008-12-17 上传
2023-06-02 上传
2021-01-20 上传
2021-01-01 上传
174 浏览量
2024-04-07 上传
weixin_38715094
- 粉丝: 4
- 资源: 916