自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

淺析基于ASP.NET網(wǎng)頁的C#數(shù)據(jù)采集

開發(fā) 后端
在好奇的動(dòng)力下,開始瘋狂的查閱以及學(xué)習(xí)關(guān)于網(wǎng)頁采集,數(shù)據(jù)采集等相關(guān)信息。不過網(wǎng)上大部都是ASP的和PHP的,關(guān)于.NET的很少。無奈之下只要硬著頭皮學(xué)習(xí)。這里簡單介紹下基于ASP.NET網(wǎng)頁的C#數(shù)據(jù)采集。

經(jīng)過幾天的努力,最終還是給我研究出來了。心里還是挺高興的襖。其實(shí)網(wǎng)頁采集也沒有用到什么高深的技術(shù),都是些普普通通的技術(shù),只不過效果比較神奇,就會(huì)讓人感覺到整個(gè)都比較深?yuàn)W,如果你想學(xué)習(xí).NET的數(shù)據(jù)采集,以及思路,那么請看完。

C#數(shù)據(jù)采集大體可以分為兩部曲:

一部曲:

因?yàn)橐杉瘎e人網(wǎng)頁上的內(nèi)容,所有我們先要得到要采集網(wǎng)頁上的html代碼,獲取html代碼還是比較簡單。利用WebClient的DownloadData(url)得帶byte數(shù)組,然后在轉(zhuǎn)換成string字符串。

具體代碼如下:

  1. ///<summary>  
  2. ///獲取網(wǎng)頁源代碼  
  3. ///</summary>  
  4. ///<paramname="url">URL路徑</param>  
  5. ///<paramname="encoding">編碼方式</param>  
  6. publicstringGetHTML(stringurl,stringencoding)  
  7. {  
  8. WebClientweb=newWebClient();  
  9. byte[]buffer=web.DownloadData(url);  
  10. returnEncoding.GetEncoding(encoding).GetString(buffer);  

二部曲:

現(xiàn)在我們得到了目標(biāo)網(wǎng)頁的html代碼,那么我們就開始時(shí)得扣取我們想要的數(shù)據(jù)。扣取數(shù)據(jù)無疑就要用到強(qiáng)大的正則表達(dá)式了。利用正則表達(dá)式的匹配來獲取我們要的內(nèi)容,這里可以過濾掉制定的html代碼,剩下的就是內(nèi)容了。

C#數(shù)據(jù)采集具體代碼如下:

  1. Htmlhtml=newHtml();  
  2. //得到指定頁面的html代碼,***個(gè)參數(shù)為url(貌似都知道),第二個(gè)是目標(biāo)網(wǎng)頁的編碼集  
  3. stringhtmlCode=html.GetHTML("http://gvod.tom59.cn/List.asp?ClassId=3","gb2312");  
  4. //正則表達(dá)式  
  5. Regexregexarticles=newRegex("<td\\s+height=\"\\d+\"><a\\s+href=\".+DataId=(?<id>\\d+)\"\\s+target=\"_blank\">(?<title>.+)</a>.*</td>");  
  6. //所有匹配表達(dá)式的內(nèi)容  
  7. MatchCollectionmarticles=regexarticles.Matches(htmlCode);  
  8. ///遍歷匹配內(nèi)容  
  9. foreach(Matchminmarticles)  
  10. {  
  11. Console.Write("標(biāo)題:"+m.Groups["title"].Value+"\n");  
  12. Console.Write("id:"+m.Groups["id"].Value+"\n");  
  13. Console.Write("\n");  

以上就是C#數(shù)據(jù)采集的核心代碼,關(guān)于正則表達(dá)式我在這里就不詳細(xì)講解了(其實(shí)正則表達(dá)式我也是菜鳥哈)。

C#數(shù)據(jù)采集結(jié)語:

大部分看似很神奇的功能,都是我們平常所用的功能拼加起來的,其實(shí)仔細(xì)分析起來也沒有多大的難度,只要能夠認(rèn)真研究。

本文來自畫上句號新浪博客文章《asp.net/C#網(wǎng)頁數(shù)據(jù)采集

【編輯推薦】

  1. C#反射方法學(xué)習(xí)總結(jié)
  2. 淺談C#測量cpu性能
  3. C#遠(yuǎn)程計(jì)算機(jī)的一些理論知識(shí)
  4. 淺析C# Static修飾
  5. C#轉(zhuǎn)換農(nóng)歷的簡單方法
責(zé)任編輯:彭凡 來源: 新浪博客
相關(guān)推薦

2009-08-04 10:02:36

中國站長站

2009-07-29 10:52:09

數(shù)據(jù)采集程序ASP.NET技巧

2009-07-27 15:34:11

MembershipASP.NET

2009-07-27 10:18:12

TypeResolveASP.NET

2009-08-03 18:35:51

ASP.NET數(shù)據(jù)緩存

2009-07-24 13:41:15

ASP.NET AJA

2009-08-05 18:36:12

ASP.NET Che

2009-07-31 12:43:59

ASP.NET MVC

2009-08-05 15:50:13

ASP.NET優(yōu)點(diǎn)

2009-08-20 10:13:49

ASP.NET和C#的

2009-07-22 18:03:00

ASP.NET ASP

2009-08-03 14:33:02

.NET平臺(tái)c#ASP.NET

2009-08-10 13:32:15

ASP.NET TimASP.NET組件設(shè)計(jì)

2009-07-31 18:12:58

ASP.NET數(shù)據(jù)綁定

2009-07-28 17:03:55

ASP.NET VB.

2009-07-29 14:12:45

ASP.NET tra

2009-07-28 17:36:21

ASP.NET數(shù)據(jù)庫連

2009-08-04 14:56:34

ASP.NET數(shù)據(jù)類型

2009-07-31 09:57:47

ASP.NET數(shù)據(jù)庫緩

2009-08-04 15:20:59

ASP.NET數(shù)據(jù)驗(yàn)證數(shù)據(jù)驗(yàn)證控件
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號