0

私はwatin dllを使用してWebページを閲覧し、liタグのリンクをクリックし、次のページに移動し、データを取得し、前のページに戻って次のliタグのリンクをクリックしています。

liタグ内の 1 つのリンクでこれを行うことができます。各リンクをクリックしてすべてのliタグを取得しul <classname>、上記の手順を実行します。li各ページをすべて取得してループするにはどうすればよいですか?

ページの HTML コードは次のようになります。

<ul id="ul_classname" class="search-result-set">
    <li class="">
        <div class="Div_Classname">
            <h3 class="standard_font">
                <a class="a class_name" href="link to be clicked">text to be displayed</a>
            </h3>
            <p class="word-wrap"></p>
        </div>
    </li>
    <li class="">
        <div class="Div_Classname">
            <h3 class="standard_font">
                <a class="a class_name" href="link to be clicked">text to be displayed</a>
            </h3>
            <p class="word-wrap"></p>
        </div>
    </li>
</ul>
4

3 に答える 3

1

これを試して:

LinkCollection links = ie.Links;
foreach (var link in links)
{
    link.Click();
    // Do something
    ie.Back();
}
于 2012-07-04T07:32:58.173 に答える
1

このコードで試すことができます(Linq to XML)

var xdoc = XDocument.Load(yourFile);

var terms= from term in xdoc.Descendants("ul")
        select new
        {
              Class= term.Attribute("class").Value
        };

foreach(var li in terms)
{
   Console.Write(li.Class);
}
于 2012-07-04T06:57:58.640 に答える
1

チッ!

private void CrawlSite()
{
    int idx = 0;
    do
    {
        idx = this.ClickLink(idx);
    }
    while (idx != -1);
}

private int ClickLink(int idx)
{
    WatiN.Core.Browser browser = GetBrowser();

    ListItemCollection listItems = browser.List("ul_classname").ListItems;
    if (idx > listItems.Count - 1)
        return -1;

    Link lnk = listItems[idx].Link(Find.ByClass("a class_name"));
    lnk.Click();

    //TODO: get your data

    browser.Back();

    return idx + 1;
}
于 2012-07-04T08:57:14.690 に答える