我问的问题在CodePlex上讨论但我希望在计算器在这里更快地得到答案。

所以,我使用HTML敏捷性包在C#HTML解析。 我有以下HTML结构:

<body>
   <p class="paragraph">text</p>
   <p class="paragraph">text</p>
   <p class="specific">text</p>
   <p class="paragraph">text</p>
   <p class="paragraph">text</p>
</body>

和我需要带班“款”与p元素之后存在的所有p元素类“特定”。

有没有办法做到这一点?

感谢。

有帮助吗?

解决方案

使用。类如Mark的实例(如果这并不存在,替代任何为宜)

使用 SkipWhile

e.g。在 LINQPad 你从5,6,7

int[] a = { 6, 5, 6 ,7 };
a.SkipWhile(x=>x!=6).Skip(1).Dump();

因此根据其种类的SelectNodes回报,或者:

.SelectNodes( "/p" ).SkipWhile( p => p.Class != "specific" ).Skip(1)

.SelectNodes( "/p" ).Cast<XX>().SkipWhile( p => p.Class != "specific" ).Skip(1)

(或,难看版本)

.SelectNodes( "/p" ).SkipWhile( p => ((XX)p).Class != "specific" ).Skip(1)

(或在某些情况下 - 如果不是表达式已经适当滤波)

.SelectNodes( "/p" ).OfType<XX>().SkipWhile( p => p.Class != "specific" ).Skip(1)

编辑:我很可能建立一个扩展方法:

static class HapExtensions
{
    public IEnumerable<T> SkipUntilAfter( this IEnumerable<T> sequence, Predicate<T> predicate) {
        return sequence.SkipWhile( predicate).Skip(1);
       }
}

任何护理搜索了现有技术的用于此?任何好的名字建议吗?

其他提示

尝试此

bool latterDayParagraphs = false;
List<DocumentNode> nodes = new List<DocumentNode>();
foreach(var pElement in doc.DocumentNode.SelectNodes("/p"))
{
   if(pElement.Class != "paragraph") 
   {
      latterDayParagraphs = true;
      continue;
   }
   if(latterDayParagraphs)
   {
      nodes.Add(pElement);
   }
}
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top