Извлечение строки таблицы с определенным атрибутом с использованием пакета HTMLAGILITY - PullRequest
0 голосов
/ 06 июня 2010

Рассмотрим этот кусок кода:

<tr>
                                                <td valign=top class="tim_new"><a href="/stocks/company_info/pricechart.php?sc_did=MI42" class="tim_new">3M India</a></td>
                                                <td class="tim_new" valign=top><a href='/stocks/marketstats/indcomp.php?optex=NSE&indcode=Diversified' class=tim>Diversified</a></td>

Я хочу написать фрагмент кода, используя пакет HTMLAgility, который извлек бы ссылку в первой строке.

    using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using HtmlAgilityPack;

namespace WebScraper
{
    class Program
    {
        static void Main(string[] args)
        {
            HtmlDocument doc = new HtmlDocument();
            doc.LoadHtml("http://theurl.com");
            try
            {
                var links = doc.DocumentNode.SelectNodes("//td[@class=\"tim_new\"]");

            }
            catch (Exception ex)
            {
                Console.WriteLine(ex.Message);
                Console.WriteLine(ex.StackTrace);
                Console.ReadKey();
            }

        }
    }
}

Когда я пытаюсь вставить оператор / цикл foreach(var link in links) в блок try, выдается ошибка времени выполнения.

1 Ответ

1 голос
/ 06 июня 2010

Код doc.LoadHtml("http://theurl.com"); не будет работать. Параметр LoadHtml должен быть строкой, содержащей HTML, а не URL. Вы должны сначала получить HTML-документ, прежде чем пытаться его проанализировать.

Как только вы загрузите документ, для этого конкретного примера вы можете использовать это:

IEnumerable<string> links = doc.DocumentNode
                               .SelectNodes("//a[@class='tim_new']")
                               .Select(n => n.Attributes["href"].Value);
...