C # Linq для XML считывает несколько тегов с атрибутами

#c# #xml #linq #parsing

#c# #xml #linq #синтаксический анализ

Вопрос:

Я пытаюсь прочитать XML-файл с помощью Linq To XML, но, похоже, не могу понять, как это сделать.

У меня есть этот XML-файл:

 <?xml version="1.0" encoding="utf-8" ?>
<Thing>
    <Objects>
        <MyTag name="" num="2">
            <Date month="May" day="2" year="2006" />
        </MyTag>

        <MyTag name="" num="4">
            <Date month="May" day="22" year="2012" />
        </MyTag>

        <MyTag name="" num="2">
            <Date month="May" day="11" year="2034" />
        </MyTag>
    </Objects>
</Thing>
  

Я начал с этого запроса:

 // Load the xml
XDocument document = XDocument.Load(XML_PATH);

var query = from thing in document.Root.Descendants("Objects")
            select new
            {
                TagName = thing.Attribute("name").Value.ToString(),
                TagNum = thing.Attribute("num").Value.ToString(),

                // What do I write here to get the Date tag and attributes?
            };
  

Как мне получить Date тег и атрибуты? Не уверен, как получить следующий узел.

Я попытался распечатать TagName и TagNum внутри foreach цикла, подобного этому:

 foreach(string value in query)
{
    Console.WriteLine(value.TagName   " "   value.TagNum); 
}
  

Однако я получаю сообщение об ошибке

 CS0030  Cannot convert type '<anonymous type: string TagName, string TagNum>' to 'string'
  

Комментарии:

1. используйте foreach (var value in query)

Ответ №1:

Чтобы получить дату, просто используйте .Element() для получения дочернего элемента:

 from thing in document.Root.Descendants("Objects")
let date = thing.Element("Date")
select new
{
    TagName = (string)thing.Attribute("name"),
    TagNum = (string)thing.Attribute("num"),

    DateMonth = (string)date?.Attribute("month"),
    DateDay = (string)date?.Attribute("day"),
    DateYear = (string)date?.Attribute("year"),
};
  

Ваше foreach утверждение не компилируется, потому что вы запрашиваете строки, когда query коллекция имеет анонимный тип, возвращаемый new{} . Вы захотите использовать var вместо string :

 foreach(var value in query)
{
    Console.WriteLine(value.TagName   " "   value.TagNum); 
}
  

Комментарии:

1. Спасибо за объяснение. Многому научился из этого.

Ответ №2:

Использовать Element("elementName") метод

 var query = 
    document.Root
            .Descendants("Objects")
            .Select(obj => new
            {
                TagName = thing.Attribute("name").Value,
                TagNum = thing.Attribute("num").Value, 
                Year = thing.Element("Date").Attribute("year").Value,
                Month = thing.Element("Date").Attribute("month").Value,
                Day = thing.Element("Date").Attribute("day").Value  
            };
  

Ответ №3:

Измените его следующим образом, var введите вместо string

  foreach (var value in query)
 {
    Console.WriteLine(value.TagName   " "   value.TagNum);
 }
  

Комментарии:

1. Спасибо. Думал, что все из запроса пришло в виде строк.