如何在此HTML代码中使用HtmlAgilityPack提取电子邮件和网站地址:
<a class="email" href="mailto:babaie@irandoc.ac.ir">
<a class="" href="http://www.babaie.ir" target="_blank">www.babaie.ir</a>
我尝试了此代码,但它不适用于电子邮件:
doc.DocumentNode.SelectNodes("//a[@href= ' ' ]");
收到电子邮件:
var a = doc.DocumentNode.SelectSingleNode("//a[@class='email']");
if (a != null)
{
string href = a.Attributes["href"].Value; // TODO: Check if href exists
string email = href.Replace("mailto:", "");
}
目前尚不清楚您的网站地址与任何其他锚标签有何不同(此处没有特定的类或 ID),因此以下代码将从 html 中的任何锚点返回所有href
链接:
var urls = doc.DocumentNode.SelectNodes("//a[@href]")
.Select(a => a.Attributes["href"].Value)
.Where(href => !href.StartsWith("mailto:")) // skip emails
.ToList();