asp.net Linq To Xml上手Descendants、Elements遍历节点

Harmony ·
更新时间:2024-11-15
· 927 次阅读

首先准备一个简单但是常见的XML
代码如下:
<?xml version="1.0" encoding="utf-8" ?>
<userSet>
<userInfo id="1" name="Guozhijian">
<profile>
<phoneNumber>13818181818</phoneNumber>
<country>China</country>
</profile>
</userInfo>
<userInfo id="2" name="Zhenglanzhen">
<profile>
<phoneNumber>13919191919</phoneNumber>
<country>Korea</country>
</profile>
</userInfo>
</userSet>

测试一:
代码如下:
private void Test1()
{
XDocument xdoc = XDocument.Load(@"UserSet.xml");
var users = from u in xdoc.Descendants("userInfo")
where u.Attribute("id").Value == "1"
select u;
foreach (var u in users)
{
string name = u.Attribute("name").Value;
Console.WriteLine(name);
}
}

输出结果为:
Guozhijian
测试二
代码如下:
private void Test2()
{
XDocument xdoc = XDocument.Load(@"UserSet.xml");
var users = from u in xdoc.Root.Elements("userInfo")
where u.Element("profile").Element("phoneNumber").Value == "13919191919"
select u;
foreach (var u in users)
{
string name = u.Attribute("name").Value;
Console.WriteLine(name);
}
}

输出结果为:
Zhenglanzhen
注意:
Descendants 可遍历某节点或文档下的所有子节点
Elements 则是遍历当前节点或文档下一级的子节点 (这点区别非常重要)
非常简单的两个 class 已基本上满足普通的XML遍历。 您可能感兴趣的文章:asp.net中通过ALinq让Mysql操作变得如此简单asp.net Linq TO Sql 分页方法asp.net下Linq To Sql注意事项小结asp.net中一个linq分页实现代码asp.net 根据汉字的拼音首字母搜索数据库(附 LINQ 调用方法)asp.net Linq to Xml学习笔记asp.net LINQ中数据库连接字符串的问题asp.net Linq把数据导出到Excel的代码asp.net使用LINQ to SQL连接数据库及SQL操作语句用法分析



net XML ASP.NET TO linq elements ASP

需要 登录 后方可回复, 如果你还没有账号请 注册新账号