だから私は次の形式のhtmlを持っています:
<html>
<head>
RANDOM JAVASCRIPT AND CSS AHHHHHH!!!!!!!!
</head>
<body>
<a href="/Random/link/here">Random</a>
<a href="/Random/link/here">Random</a>
<a href="/Random/link/here">Random</a>
<a href="/Random/link/here">Random</a>
<a href="/Random/link/here">Random</a>
<a href="/Random/link/here">Random</a>
<table class="table">
<tr><a href="/subdir/members/Name">Name</a></tr>
<tr><a href="/subdir/members/Name">Name</a></tr>
<tr><a href="/subdir/members/Name">Name</a></tr>
<tr><a href="/subdir/members/Name">Name</a></tr>
<tr><a href="/subdir/members/Name">Name</a></tr>
<tr><a href="/subdir/members/Name">Name</a></tr>
<tr><a href="/subdir/members/Name">Name</a></tr>
<tr><a href="/subdir/members/Name">Name</a></tr>
<tr><a href="/subdir/members/Name">Name</a></tr>
<tr><a href="/subdir/members/Name">Name</a></tr>
</table>
<body>
</html>
そして、に含まれる情報を抽出し、その情報からのリンクを抽出する目的で作成された次のコードがあります。
public class MainClass
{
public static void Main(String[] args)
{
string url = args[1];
Extractinfo pageScrape = new Extractinfo();
pageScrape.RenderPage(url);
}
}
public class Extractinfo
{
public HtmlDocument RenderPage(string url)
{
try
{
HtmlDocument pageSource = new HtmlDocument();
var webGet = new HtmlWeb();
pageSource = webGet.Load(url);
ExtractLinks(pageSource);
}
catch (WebException e)
{
Console.WrtieLine(e.Message + ": " + e.StackTrace);
}
}
private List<string> ExtractHrefTags(HtmlNode htmlSnippet)
{
List<string> hrefTags = new List<string>();
foreach (HtmlNode link in htmlSnippet.SelectNodes("//a[@href]"))
{
HtmlAttribute att = link.Attributes["href"];
hrefTags.Add(att.Value);
}
return hrefTags;
}
public void ExtractLinks(HtmlDocument pagesource)
{
var elements = pagesource.DocumentNode.SelectNodes("//table[@class='table']");
List<string> hrefTags = new List<string>();
foreach (var ele in elements)
{
hrefTags = ExtractHrefTags(ele);
}
}
}
}
これで、内部にあるリンクだけを取得するのではなく<table class="table>*****</table>
、このコードはページ上のすべてのリンクをリストhreftagsに配置します。私はここで何が間違っているのですか?抽出されたリンクのみが内部に存在するリンクになるようにエラーを修正するにはどうすればよい<table class="table>*****</table>
ですか?
ご協力ありがとうございました!