LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

Asp.net/C#網(wǎng)頁數(shù)據(jù)采集

admin
2021年1月29日 18:17 本文熱度 3191

    早在以前就聽說過數(shù)據(jù)采集這個(gè)神奇的功能,當(dāng)時(shí)對(duì)這個(gè)是多么的奢望啊。 ~00~,后來想要給自己開個(gè)采集的網(wǎng)站,就想到了整個(gè)電影的采集站。

    在好奇的動(dòng)力下,開始瘋狂的查閱以及學(xué)習(xí)關(guān)于網(wǎng)頁采集,數(shù)據(jù)采集等相關(guān)信息。不過網(wǎng)上大部都是asp的和php的,關(guān)于.net的很少。無奈之下只要硬著頭皮學(xué)習(xí)。經(jīng)過幾天的努力,最終還是給我研究出來了。心里還是挺高興的襖。其實(shí)網(wǎng)頁采集也沒有用到什么高深的技術(shù),都是些普普通通的技術(shù),只不過效果比較神奇,就會(huì)讓人感覺到整個(gè)都比較深?yuàn)W,如果你想學(xué)習(xí).net的數(shù)據(jù)采集,以及思路,那么請(qǐng)看完。

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

一部曲:

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

          具體代碼如下:

        /// <summary>

        /// 獲取網(wǎng)頁源代碼

        /// </summary>

        /// <param name="url">URL路徑</param>

        /// <param name="encoding">編碼方式</param>

        public string GetHTML(string url, string encoding)

        {

            WebClient web = new WebClient();

            byte[] buffer = web.DownloadData(url);

            return Encoding.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)容了。

具體代碼如下:

        Html html = new Html();

        //得到指定頁面的html代碼,第一個(gè)參數(shù)為url(貌似都知道),第二個(gè)是目標(biāo)網(wǎng)頁的編碼集

        string htmlCode = html.GetHTML("http://gvod.tom59.cn/List.asp?ClassId=3", "gb2312");

        //正則表達(dá)式

        Regex regexarticles = new Regex("<td\\s+height=\"\\d+\"><a\\s+href=\".+DataId=(?<id>\\d+)\"\\s+target=\"_blank\">(?<title>.+)</a>.*</td>");

        //所有匹配表達(dá)式的內(nèi)容

        MatchCollection marticles = regexarticles.Matches(htmlCode);

        ///遍歷匹配內(nèi)容

        foreach (Match m in marticles)

        {

             Console.Write("標(biāo)題:" + m.Groups["title"].Value+"\n");

             Console.Write("id:" + m.Groups["id"].Value + "\n");

             Console.Write("\n");

}

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


該文章在 2021/1/29 18:17:01 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場(chǎng)、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場(chǎng)作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲(chǔ)管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

黄频国产免费高清视频,久久不卡精品中文字幕一区,激情五月天AV电影在线观看,欧美国产韩国日本一区二区
最新日本在线观看网站 | 香蕉日本视频线播放 | 一区二区三区字幕不卡 | 亚洲欧美综合久久久 | 亚洲色婷婷爱婷婷综合精品 | 日本免码va在线看免费99 |