0

如果遇到具有值的节点,我只想获取最后一个子节点datetime在 XML 文件中:alarmtrue

XML 看起来是这样的:

<USER>
    <date>09.07.2013</date>
    <time>08:28</time>
    <alarm>true</alarm>
</USER>
<USER>
    <date>09.07.2013</date>
    <time>08:23</time>
</USER>
<USER>
    <date>09.07.2013</date>
    <time>08:17</time>
    <alarm>true</alarm>
</USER>
<USER>
    <date>09.07.2013</date>
    <time>08:15</time>
</USER>

我的代码是:

        string URL = "http://IP";
        HttpWebRequest request = WebRequest.Create(URL) as HttpWebRequest;
        request.Credentials = new NetworkCredential("Username", "PW");

        using (HttpWebResponse response = request.GetResponse() as HttpWebResponse)
        {
            XmlReader xmlReader = XmlReader.Create(response.GetResponseStream());
            XDocument temp = XDocument.Load(xmlReader);

            var date = temp.Element("USER").Descendants("date").Select(node => node.Value.ToString()).First();
            var time = temp.Element("USER").Descendants("time").Select(node => node.Value.ToString()).First();
        }

正如我之前所说,我只想检索date并且time如果

<alarm>true</alarm>

遇到了。

4

5 回答 5

2

您可以使用以下查询来获取最后一个用户元素的日期和时间:

var lastUser = temp.Elements("User").LastOrDefault();
var date = (string)lastUser.Element("date");
var time = (string)lastUser.Element("time");
var isAlarm = (bool?)lastUser.Element("alarm");

这里的更新是查询,它将DateTime从所有用户那里获取警报值和值:

var users = from u in temp.Descendants("USER")
            let time = (string)u.Element("time")
            let date = (string)u.Element("date")
            select new {
                Date = DateTime.ParseExact(date + time, "MM.dd.yyyyHH:mm", null),
                IsAlarm = (bool?)u.Element("alarm") ?? false
            };

您将能够获取最后一个用户的日期、具有最大日期的用户,或按警报值过滤用户。例如获取最后一次警报的时间:

var user = users.Where(u => u.IsAlarm).OrderBy(u => u.Date).LastOrDefault();
if (user != null)
    date = user.Date;
于 2013-07-09T13:21:29.800 回答
2

您可以使用以下代码获取最后一个节点:

var lastNode = doc.Root.Elements().Where(p => p.Name == "USER" && p.Elements().Any(o => o.Name == "alarm" && o.Value == "true")).Last();
于 2013-07-09T13:48:10.867 回答
1

行,

var yourUser = temp.Root.Elements("USER").LastOrDefault(u => 
    u.Elements("alarm").Any(a => a.Value == true));

if (yourUser != null)
{
   var dateTime = DateTime.ParseExact(
       (string)yourUser.Element("date") + (string)yourUser.Element("time"),
       "dd.MM.yyyyHH:mm");
}
于 2013-07-09T13:27:34.833 回答
0

更直接的替代方法是使用更老式的 XPath,通过XPathSelectElements找到最后一个 USER alarm = true,如下所示:

 var lastUser = xdoc.XPathSelectElements("//USER[alarm='true']")
                    .LastOrDefault();
 var lastUserDate = lastUser.Element("date").Value;
 var lastUserTime = lastUser.Element("time").Value;

AFAIK 这或多或少等同于 Linq:

 var lastUser = xdoc.Descendants("USER")
                    .LastOrDefault(u => u.Element("alarm") != null 
                                     && u.Element("alarm").Value == "true");
 var lastUserDate = lastUser.Element("date").Value;
 var lastUserTime = lastUser.Element("time").Value;
于 2013-07-09T13:35:20.383 回答
0

使用 XElement 而不是 XDocument,这样您就可以循环 xml 内容的所有元素和属性

XElement temp = XElement.Load(xmlReader);

之后,只需这样做:

foreach (XElement user in temp.Elements("USER"))
{
    var alarm = user.Element("alarm");

    if (alarm != null && alarm.Value == "true")
    {
        var date = user.Elements("date").Last().Value;
        var time = user.Elements("time").Last().Value;
    }
}
于 2013-07-09T13:37:49.623 回答