Поэтому я пытаюсь разобрать html с xpath. Вот как выглядит моя страница
<area id="a_0_0" alt="asd">
<area id="a_0_1" alt="asd">
<area id="a_1_0" alt="asd">
<area id="a_1_1" alt="asd">
Так возможно ли разобрать его с помощью xpath? или мне нужно использовать что-то еще? Я немного новичок в xpath, вот что я пробовал
doc.DocumentNode.SelectSingleNode("//area[@id='a_0_0']").Attributes["alt"].Value;//this is works
doc.DocumentNode.SelectSingleNode("//area[@id='a_0_[position() >=0 and position() <=1]']").Attributes["alt"].Value
doc.DocumentNode.SelectSingleNode("//area[@id='a_[position() >=0 and position() <=1]']_[position() >=0 and position() <=1]']").Attributes["alt"].Value
2 ответа
Вот простое решение.
var nodes = doc.DocumentNode.SelectNodes("//area[contains('a_0_0,a_0_1,a_1_0,a_1_1',id)]")
foreach (var node in nodes)
{
// node.Attributes["alt"].Value
}
Также вы можете использовать ниже, чтобы получить все узлы области, которые имеют атрибут alt.
var nodes = doc.DocumentNode.SelectNodes("//area[@alt]");
Чтобы получить все узлы области, которые начинаются с a_
, используйте ниже.
var nodes = doc.DocumentNode.SelectNodes("//area[starts-with(@id,'a_')][@alt]);
Вы можете проанализировать ваш xml в XDocument и воспользоваться linq.
XDocument.Parse(xmlstring)
Похожие вопросы
Новые вопросы
c#
C # (произносится как «резкий») - это высокоуровневый, статически типизированный язык программирования с несколькими парадигмами, разработанный Microsoft. Код C # обычно нацелен на семейство инструментов и сред выполнения Microsoft .NET, включая, среди прочего, .NET Framework, .NET Core и Xamarin. Используйте этот тег для вопросов о коде, написанном на C # или в формальной спецификации C #.