使用LINQ to XML时如何检查XML是否包含元素?

efl*_*les 5 c# xml linq

鉴于这种结构:

 <root>
     <user>
           <userName>user1</userName>
           <userImageLocation>/user1.png</userImageLocation>
     </user>
     <user>
           <userName>user2</userName>
     </user>
 </root>

public class User
{
    public string UserName {get; set; }
    public string UserImageLocation {get; set; }
}
Run Code Online (Sandbox Code Playgroud)

我使用LINQ to XML从XML文件中获取数据,如下所示:

XDocument document = XDocument.Parse(xmlFile);
List<User> listOfUsers =  
(from user in document.Descendants("user")
 select new User {
    UserName = user.Element("userName"),
    UserImageLocation = user.Element("userImageLocation"),
 }
).ToList<User>();
Run Code Online (Sandbox Code Playgroud)

我的问题是并非所有user元素都包含userImageLocation,并且在尝试读取userImageLocation时,它会抛出异常.

如何检查XML元素是否存在,如果存在,请阅读它?

Jon*_*eet 8

您当前的代码将无法编译,因为您正在尝试将XElement字符串属性分配给它.我的猜测是你正在使用该XElement.Value属性将其转换为字符串.而不是那样,使用显式字符串转换,如果你在空XElement引用上"调用"它将返回null :

XDocument document = XDocument.Parse(xmlFile);
List<User> listOfUsers =  
(from user in document.Descendants("user")
 select new User {
    UserName = (string) user.Element("userName"),
    UserImageLocation = (string) user.Element("userImageLocation"),
 }
).ToList<User>();
Run Code Online (Sandbox Code Playgroud)

请注意,这是使用点表示法更具可读性的情况之一:

XDocument document = XDocument.Parse(xmlFile);
List<User> listOfUsers = document
    .Descendants("user")
    .Select(user => new User { 
         UserName = (string) user.Element("userName"),
         UserImageLocation = (string) user.Element("userImageLocation") })
    .ToList();
Run Code Online (Sandbox Code Playgroud)