c #LinQ到xml多一个

时间:2015-09-12 21:44:11

标签: c# xml linq

任何人都可以帮我处理这段代码我不知道这里有什么问题。我想从XML中检索数据,其中日期是2015/9/12和2015/9/13。

        var events = (from item in xdocument.Descendants("Event")
                      where (string)item.Element("Date") == "2015/9/12" &&
                      (string)item.Element("Date") == "2015/9/13"
                      select (string)item.Element("Date")).ToList();
        foreach (string name in events)
        {
            MessageBox.Show(name);
        }

这是我的XML文件。

<?xml version="1.0" encoding="utf-8"?>
<Events>
  <Event ID="0">
    <Name>test</Name>
    <Date>2015/9/12</Date>
    <Priority>0</Priority>
    <Created_at>0000</Created_at>
  </Event>
  <Event ID="1">
    <Name>test1</Name>
    <Date>2015/9/13</Date>
    <Priority>0</Priority>
    <Created_at>0000</Created_at>
  </Event>
  <Event ID="2">
    <Name>test2</Name>
    <Date>2015/9/15</Date>
    <Priority>2</Priority>
    <Created_at>0000</Created_at>
  </Event>
</Events>

1 个答案:

答案 0 :(得分:0)

您需要做的第一件事是修改您的xml。您的日期标记上有标记不匹配。你有<Date>2015/9/12</Data>。请注意您的结束标记是数据而不是日期。然后,您可以执行以下操作:

var events = doc.Descendants("Event").Where(x => x.Element("Date").Value == "2015/9/12" || x.Element("Date").Value == "2015/9/13");