XML 查询并不总是提取结果



我一直在玩XML,试图了解它是如何工作的,遇到了一个奇怪的问题。有时,当我查询我的 XML 文件时,我没有得到我知道存在的结果。事实上,我唯一得到结果的是第一个条目。下面是一些示例 XML 条目和一个用于查看用户是否存在的小函数。

<users>
  <user>
    <username>a</username>
    <firstname>a</firstname>
    <lastname>a</lastname>
  </user>
  <user>
    <username>b</username>
    <firstname>b</firstname>
    <lastname>b</lastname>
  </user>
  <user>
    <username>rawr</username>
    <firstname>a</firstname>
    <lastname>a</lastname>
  </user>
</users>

>

private bool FindUser(string username)
{
        XDocument doc = XDocument.Load(filePath);

        var data = from item in doc.Descendants("users")
                   where item.Element("user").Element("username").Value == username.ToLower()
                   select new
                   {
                       usernameEle = item.Element("user").Element("username").Value
                   };
        var p = data.FirstOrDefault();
        if (p != null)
            return true;
        else
            return false;
}

如果我尝试搜索用户"a",它会返回 true。如果我搜索任何其他用户名,它会返回 false。

确信有一个简单的解决方案,但它躲避了我!任何帮助都会很棒。

您的查询只是查看第一个user元素。 您希望更改它以查看所有用户。 一种简单的方法是获取所有"用户"元素,然后在有答案时测试用户名值。

较短的实现方式是:

bool IsUserPresent(string username)
{
    username = username.ToLower();
    var doc = XDocument.Load(filePath);
    return doc
      .Descendants("user")
      .Any(u => u.Element("username").Value == username));
}

我想出了答案...但我不确定为什么会起作用。我对 XML 还是有些陌生...

我更改了"项目。元素("用户")。元素("用户名")。值"到"项。元素("用户名")。价值"。也更改了"从文档中的项目。后代("用户")"到"从文档中的项目。后代("用户")"

var data = from item in doc.Descendants("users")
           where item.Element("user").Element("username").Value == username.ToLower()
           select new
           {
               usernameEle = item.Element("user").Element("username").Value
           };

var data = from item in doc.Descendants("user")
           where item.Element("username").Value == username.ToLower()
           select new
           {
               usernameEle = item.Element("username").Value
           };

它现在能够检索的不仅仅是第一个条目。如果我搜索 b 或 rawr,我会得到适当的结果。

奇怪。

相关内容

  • 没有找到相关文章

最新更新