HtmlAgilityPack是一個開源的解析HTML元素的類庫,最大的特色是能夠經過XPath來解析HMTL,若是您之前用C#操做過XML,那麼使用起HtmlAgilityPack也會駕輕就熟。目前版本更新的是很是的快,最新更新時間仍是19年的呢!html
XPath即爲XML路徑語言,它是一種用來肯定XML(標準通用標記語言的子集)文檔中某部分位置的語言。XPath基於XML的樹狀結構,提供在數據結構樹中找尋節點的能力。起初 XPath 的提出的初衷是將其做爲一個通用的、介於XPointer與XSL間的語法模型。可是 XPath 很快的被開發者採用來看成小型查詢語言。java
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using HtmlAgilityPack; using System.IO; using System.Net; namespace DataGridViewDemo { public class HttpHelper { static readonly string urlTemplate = "http://yun.java1234.com/search?page={0}&q={1}"; public static List<BDWPResource> Request(string key, string start) { string url = string.Format(urlTemplate, key, start); HttpWebRequest httpRequest = (HttpWebRequest)WebRequest.Create(url); httpRequest.Accept = "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8"; httpRequest.UserAgent = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36"; try { HtmlWeb webClient = new HtmlWeb(); HtmlDocument doc = webClient.Load(url); if (doc != null) { //加載文檔對象 { var content = doc.DocumentNode.SelectSingleNode("/html/body/div[2]/div[3]/div/div/div[2]/ul"); if (content != null) { List<BDWPResource> list = new List<BDWPResource>(); var targetLi = content.SelectNodes(@"li"); foreach (var item in targetLi) { list.Add(new BDWPResource() { title = item.SelectSingleNode("span[1]/a").InnerText, unescapedUrl = "http://yun.java1234.com/" + item.SelectSingleNode("span[1]/a").Attributes["href"].Value.Trim(), content = item.SelectSingleNode("span[2]").InnerText.Trim() }); } return list; } } return null; } else { return null; } } catch { return null; } } } }