#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. Спасибо. Думал, что все из запроса пришло в виде строк.