繁体   English   中英

具有嵌套循环的Linq XML查询 - 1

[英]Linq XML query with nested loop - 1

这个问题中 ,如果我需要在输出中包含“日期”,应该进行哪些更改?

当我包括在内

let dt = l.Element("Date").Value

它给出了“对象引用未设置为对象的实例”

var query = from l in doc.Descendants("L1")
            let dt = l.Element("Date").Value
            let id = l.Attribute("id").Value
            from subject in l.Descendants("Subject")
            select new
            {
                Date = dt,
                Id = id,
                SubjectName = (string)subject.Attribute("SubjectName"),
                Score = (string)subject.Attribute("Score")
            };


foreach (var result in query)
{
    Console.WriteLine(result);
}

如果l没有Date元素,则尝试访问l.Element("Date").Value将导致错误。 您可以使用条件:

var query = from l in doc.Descendants("L1")
        let dt = l.Elements("date").Any() 
                 ? l.Element("date").Value
                 : AnyDefaultValueIWantForDate
        let id = l.Attribute("id").Value
        from subject in l.Descendants("Subject")
        select new
        {
            Date = dt,
            Id = id,
            SubjectName = subject.Attribute("SubjectName").Value,
            Score = subject.Attribute("Score").Value
        };

(我还在SubjectNameScore添加了.Value )。

假设l不为null,则l.Element("Date")为null,这意味着您的一个或多个L1元素没有子Date元素。

修复程序取决于您想要丢失日期的内容。 如果要将default(DateTime)用作“魔术”日期,则可以执行以下操作:

let dt = (l.Element("Date") == null ? default(DateTime) : l.Element("Date").Value)

看看你的其他XML,正如Skeet先生所提到的那样,它没有<date>元素中的任何内容。 如果您不打算总是在那里有数据,则需要明确地处理它。

你可以这样做:

let dt = l.Element("date") == null ? string.Empty : l.Element("date").Value 

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM