亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

c#爬蟲爬取京東的商品信息

2019-10-29 19:41:23
字體:
來源:轉載
供稿:網友

前言

在一個小項目中,需要用到京東的所有商品ID,因此就用c#寫了個簡單的爬蟲。

在解析HTML中沒有使用正則表達式,而是借助開源項目HtmlAgilityPack解析HTML。

下面話不多說了,來一起看看詳細的介紹吧

一、下載網頁HTML

首先我們寫一個公共方法用來下載網頁的HTML。

在寫下載HTML方法之前,我們需要去查看京東網頁請求頭的相關信息,在發送請求時需要用到。

public static string DownloadHtml(string url, Encoding encode){ string html = string.Empty; try { HttpWebRequest request = WebRequest.Create(url) as HttpWebRequest; request.Timeout = 30 * 1000; request.UserAgent = "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.106 Safari/537.36"; request.ContentType = "text/html; charset=utf-8"; using (HttpWebResponse response = request.GetResponse() as HttpWebResponse) {  if (response.StatusCode == HttpStatusCode.OK)  {  try  {   StreamReader sr = new StreamReader(response.GetResponseStream(), encode);   html = sr.ReadToEnd();//讀取數據   sr.Close();  }  catch (Exception ex)  {   html = null;  }  } } } catch (System.Net.WebException ex) {  html = null; } catch (Exception ex) { html = null; } return html;}

如上代碼所示,我們使用WebRequest來獲取網頁信息,在發送請求之前,需要先設置和京東頁面一樣的請求頭。

以上設置的信息比較簡單,但能夠正常發送請求,我們也可以模擬瀏覽器設置cookie等等信息,

二、解析HTML

獲取所有商品的信息分為兩個步驟

    (1)根據商品分類頁面獲取所有商品分類的URL

    (2)根據商品分類URL獲取每個商品

 1、獲取商品分類

try{ string html = HttpHelper.DownloadUrl(@"http://www.jd.com/allSort.aspx"); HtmlDocument doc = new HtmlDocument(); doc.LoadHtml(html); string goodClass= @"//*[@class='items']/dl/dd"; HtmlNodeCollection noneNodeList = doc.DocumentNode.SelectNodes(goodClass); foreach (var node in noneNodeList) { HtmlDocument docChild = new HtmlDocument(); docChild.LoadHtml(node.OuterHtml); string urlPath = "/dd/a"; HtmlNodeCollection list = docChild.DocumentNode.SelectNodes(urlPath); foreach (var l in list) {  HtmlDocument docChild1 = new HtmlDocument();  docChild1.LoadHtml(l.OuterHtml);  var sortUrl = l.Attributes["href"].Value;  if (!string.IsNullOrWhiteSpace(sortUrl) && sortUrl.Contains("cat="))  {  InsertSort("https:" + sortUrl);  } } }}catch (Exception ex){ Console.WriteLine(ex.Message);}

上面的代碼中使用到了HtmlAgilityPack來解析HTML信息,這是.NET的開源項目,開源在nuget包中下載。

      (1)下載http://www.jd.com/allSort.aspx的html頁,然后加載到HtmlDocument

      (2)選擇節點,獲取每個大類的節點集合

      (3)根據每個大類的節點,獲取每個小類的節點信息,然后獲取到分類地址

節點中也包含了其它很多信息,可以根據自己的需求去獲取對應的信息

2、獲取具體商品信息

(1)首先根據商品分類加載分類信息,獲取到當前分類每個頁面的鏈接

下載HTML之后,選擇節點,可以將HTML格式化之后查看每個頁面的url地址和拼接規則,然后借助HtmlAgilityPack

來篩選需要的節點,將每個頁面的url分離出來

try{ string html = HttpHelper.DownloadUrl(@"https://list.jd.com/list.html?cat=1620,11158,11964"); HtmlDocument productDoc = new HtmlDocument(); productDoc.LoadHtml(html); HtmlNode pageNode = productDoc.DocumentNode.SelectSingleNode(@"//*[@id='J_topPage']/span/i"); if (pageNode != null) {  int pageNum = Convert.ToInt32(pageNode.InnerText);  for (int i = 1; i < pageNum + 1; i++)  {   string pageUrl = string.Format("{0}&page={1}", category.Url, i).Replace("&page=1&", string.Format("&page={0}&", i));   try   {    List<ProductInfo> proDuctInfo = GetPageProduct(pageUrl);   }   catch (Exception ex)   {    Console.WriteLine(ex.Message);   }  } } }catch (Exception ex){ Console.WriteLine(ex.Message);}

(2)根據每個頁面的鏈接,獲取當前頁面的商品信息

下載每個頁面的所有商品信息,需要獲取的商品信息在頁面中都能找到

首先我們獲取到每個商品的節點集合,獲取到一個商品的節點信息之后,分析html數據,

找到我們需要的商品的信息所在的位置,然后將需要的信息分離出來。

下面的代碼中我獲取到的商品的id和title還有價格。

List<ProductInfo> productInfoList = new List<ProductInfo>();try{ string html = HttpHelper.DownloadUrl(url); HtmlDocument doc = new HtmlDocument(); doc.LoadHtml(html); HtmlNodeCollection productNodeList = doc.DocumentNode.SelectNodes("//*[@id='plist']/ul/li"); if (productNodeList == null || productNodeList.Count == 0) {  return productInfoList; } foreach (var node in productNodeList) {  HtmlDocument docChild = new HtmlDocument();  docChild.LoadHtml(node.OuterHtml);  ProductInfo productInfo = new ProductInfo()  {   CategoryId = category.Id  };   HtmlNode urlNode = docChild.DocumentNode.SelectSingleNode("//*[@class='p-name']/a");  if (urlNode == null)  {   continue;  }  string newUrl= urlNode.Attributes["href"].Value;  newUrl = !newUrl.StartsWith("http:")?"http:" + newUrl: newUrl;  string sId = Path.GetFileName(newUrl).Replace(".html", "");  productInfo.ProductId = long.Parse(sId);  HtmlNode titleNode = docChild.DocumentNode.SelectSingleNode("//*[@class='p-name']/a/em");  if (titleNode == null)  {   continue;  }  productInfo.Title = titleNode.InnerText;    HtmlNode priceNode = docChild.DocumentNode.SelectSingleNode("//*[@class='p-price']/strong/i");  if (priceNode == null)  {   continue;  }  else  {   }  productInfoList.Add(productInfo);   } //批量獲取價格 GetGoodsPrice(productInfoList);}catch (Exception ex){}return productInfoList;

商品的圖片地址和價格信息的獲取需要仔細分析html中的數據,然后找到規律,比如價格在每個節點中就不能單獨獲取。

以下為批量獲取價格的代碼:

try   {    StringBuilder sb = new StringBuilder();    sb.AppendFormat("http://p.3.cn/prices/mgets?callback=jQuery1069298&type=1&area=1_72_4137_0&skuIds={0}&pdbp=0&pdtk=&pdpin=&pduid=1945966343&_=1469022843655", string.Join("%2C", productInfoList.Select(c => string.Format("J_{0}", c.ProductId))));    string html = HttpHelper.DownloadUrl(sb.ToString());    if (string.IsNullOrWhiteSpace(html))    {     return productInfoList;    }    html = html.Substring(html.IndexOf("(") + 1);    html = html.Substring(0, html.LastIndexOf(")"));    List<CommodityPrice> priceList = JsonConvert.DeserializeObject<List<CommodityPrice>>(html);    productInfoList.ForEach(c => c.Price = priceList.FirstOrDefault(p => p.id.Equals(string.Format("J_{0}", c.ProductId))).p);   }   catch (Exception ex)   {    Console.WriteLine(ex.Message);   }   return productInfoList;

以上就是一個簡單的爬取京東商品信息的爬蟲,也可以根據自己的需求去解析更多的數據出來。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。


注:相關教程知識閱讀請移步到c#教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美极品少妇xxxxⅹ裸体艺术| 国产乱肥老妇国产一区二| 亚洲第一福利在线观看| 欧美福利视频在线观看| 午夜精品久久久久久久久久久久久| 日韩av最新在线| 91视频免费网站| 热久久99这里有精品| 精品久久久久久亚洲国产300| 久久久久久久一区二区三区| 国产精品免费久久久久久| 亚洲国产日韩欧美综合久久| 久久影视免费观看| 成人黄色免费片| 欧美肥老妇视频| 韩国国内大量揄拍精品视频| 91在线免费看网站| 国产精品白嫩初高中害羞小美女| 欧美日本亚洲视频| 精品欧美一区二区三区| 成人黄色片在线| 丝袜情趣国产精品| 国产成人在线播放| 国内精品久久久久久影视8| 亚洲欧美激情在线视频| 日韩精品有码在线观看| 成人美女av在线直播| 国产伦精品免费视频| 在线播放日韩专区| 川上优av一区二区线观看| 国产成人在线精品| 日韩的一区二区| 国产精品久久久久久久久久99| 欧美丰满老妇厨房牲生活| 韩国三级电影久久久久久| 国产欧洲精品视频| 国产美女被下药99| 成人国产精品av| 亚洲午夜精品视频| 亚洲影院色在线观看免费| 国产精品成久久久久三级| 欧美精品福利在线| 另类图片亚洲另类| 久久精品99久久久久久久久| 精品日本美女福利在线观看| 国产热re99久久6国产精品| 青青精品视频播放| www.日韩不卡电影av| 亚洲视频综合网| 欧美日韩成人黄色| 97久久伊人激情网| 九九久久久久久久久激情| 久久精品国产欧美亚洲人人爽| 国产欧美欧洲在线观看| 亚洲18私人小影院| 欧美日韩福利在线观看| 国产精品一区=区| 国产一区二区三区在线观看视频| 欧美最顶级丰满的aⅴ艳星| 欧美激情第三页| 日韩成人在线视频观看| 成人h片在线播放免费网站| 欧美国产日韩xxxxx| 欧美俄罗斯性视频| 国产精品视频免费在线观看| 91精品国产高清久久久久久91| 久久亚洲国产精品成人av秋霞| 精品免费在线观看| 91在线观看免费网站| 国产日韩一区在线| 欧美成人免费网| 亚洲国产精品人久久电影| 精品一区电影国产| 国内精品久久久久久| 亚洲成年人影院在线| 国产一区深夜福利| 日韩中文字幕网站| 亚洲黄色av网站| 91网站免费观看| 国产激情久久久久| 日韩在线观看成人| 欧美与欧洲交xxxx免费观看| 亚洲精品日韩欧美| 91精品国产91久久久久久| 精品国产乱码久久久久久天美| 欧美成人网在线| 亚洲自拍偷拍第一页| 欧美午夜女人视频在线| 97国产成人精品视频| 18性欧美xxxⅹ性满足| 日韩高清av在线| 亚洲毛茸茸少妇高潮呻吟| 日本不卡高字幕在线2019| 91社区国产高清| 精品视频久久久| 日韩成人在线视频网站| 中文字幕精品视频| 久久久免费精品视频| 韩国视频理论视频久久| 亚洲欧洲美洲在线综合| 九九热在线精品视频| 欧洲成人免费aa| 中国日韩欧美久久久久久久久| 欧美日韩中文在线观看| 国产精品久久久久av| 成人福利视频在线观看| 欧美老女人xx| 日本人成精品视频在线| 欧美国产日韩精品| 一道本无吗dⅴd在线播放一区| 精品日本高清在线播放| 川上优av一区二区线观看| 欧美性色视频在线| 国产一区二区三区在线观看视频| 欧美最猛黑人xxxx黑人猛叫黄| 欧美黑人性视频| 亚洲老板91色精品久久| 欧美视频在线观看免费| 91高清免费视频| 成人国产精品久久久久久亚洲| 不卡av在线网站| 欧美午夜宅男影院在线观看| 欧美激情第一页xxx| 在线看片第一页欧美| 亚洲精品天天看| 中文字幕国产精品| 姬川优奈aav一区二区| 丰满岳妇乱一区二区三区| 久久精品国产v日韩v亚洲| 中文字幕日韩在线观看| 大胆欧美人体视频| 日韩中文字幕av| 国产亚洲一区二区在线| 国产一区二中文字幕在线看| 久久成人av网站| 国产一区二区丝袜高跟鞋图片| 欧美精品在线观看91| 欧美性生交xxxxxdddd| 成人a在线视频| 国产精品视频不卡| 亚洲成人精品在线| 亚洲网在线观看| 成人妇女免费播放久久久| 国外成人免费在线播放| 国内免费精品永久在线视频| 亚洲人成欧美中文字幕| 成人免费在线视频网站| 秋霞午夜一区二区| 中文字幕欧美专区| 成人乱人伦精品视频在线观看| 国产精品高清在线| 日韩毛片在线看| 日韩电影中文字幕一区| 亚洲在线www| 91国产在线精品| 色噜噜狠狠狠综合曰曰曰88av| 欧美成年人视频网站欧美| 精品免费在线视频| 欧美裸体xxxx极品少妇| 成人免费高清完整版在线观看| 日韩av片电影专区| 91性高湖久久久久久久久_久久99| 欧美一级视频免费在线观看| 秋霞av国产精品一区|