搜索引擎——網(wǎng)絡(luò)爬蟲

最近寫了一個(gè)簡(jiǎn)單的搜索引擎黑毅,將網(wǎng)易首頁(yè)中的新聞扒下來(lái)進(jìn)行整理暑中,并能夠進(jìn)行搜索棍郎。
以下使用的開發(fā)環(huán)境是eclipse其障。
上工程結(jié)構(gòu)圖:

首先講解網(wǎng)絡(luò)爬蟲部分。
網(wǎng)絡(luò)爬蟲(又被稱為網(wǎng)頁(yè)蜘蛛涂佃,網(wǎng)絡(luò)機(jī)器人励翼,在FOAF社區(qū)中間,更經(jīng)常的稱為網(wǎng)頁(yè)追逐者)辜荠,是一種按照一定的規(guī)則汽抚,自動(dòng)地抓取萬(wàn)維網(wǎng)信息的程序或者腳本。
在這里伯病,用到了jsoup 造烁。jsoup 是一款Java 的HTML解析器,可直接解析某個(gè)URL地址午笛、HTML文本內(nèi)容惭蟋。它提供了一套非常省力的API,可通過DOM药磺,CSS以及類似于jQuery的操作方法來(lái)取出和操作數(shù)據(jù)告组。
jsoup開發(fā)手冊(cè) http://www.open-open.com/jsoup/
jsoup下載地址 http://jsoup.org/download
jsoup的jar包下載之后,導(dǎo)入我們的工程里就行了癌佩。
以下是獲取首頁(yè)中社會(huì)新聞的超鏈接以及插入數(shù)據(jù)庫(kù)的代碼木缝。

import java.sql.*;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
import org.jsoup.select.Elements;
public class getURL{
    public static void main(String[] args) {
        try{
        Document doc = Jsoup.connect("http://www.163.com").get();
        Elements link=doc.select("a[href^=http://news.163.com/15]");
        System.out.println("Links: "+link.size());
        for (Element links : link) {            
           String url=links.attr("href");
                 System.out.println( url);
                 Class.forName("com.mysql.jdbc.Driver");
                 Connection conn=DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/search?useUnicode=true&characterEncoding=utf-8","root","123456");
                 System.out.println(url);
                 PreparedStatement pstmt=conn.prepareStatement("insert into geturl(url)values(?)");
                 pstmt.setString(1,url);
                 pstmt.executeUpdate();    
        }
    }catch(Exception e){
        System.out.print("錯(cuò)誤:"+e.getMessage());
    }
        

    }

}

程序運(yùn)行結(jié)果如下

Links: 69
http://news.163.com/15/1018/10/B6714LQS00011229.html#f=resyswwwrank
http://news.163.com/15/1018/10/B6714LQS00011229.html#f=resyswwwrank
http://news.163.com/15/1018/01/B663HA6D00014Q4P.html#f=resyswwwrank
http://news.163.com/15/1018/01/B663HA6D00014Q4P.html#f=resyswwwrank
http://news.163.com/15/1018/00/B65VL94N00014AED.html#f=resyswwwrank
http://news.163.com/15/1018/00/B65VL94N00014AED.html#f=resyswwwrank
http://news.163.com/15/1018/09/B66S1BLF00011229.html#f=resyswwwrank
http://news.163.com/15/1018/09/B66S1BLF00011229.html#f=resyswwwrank
http://news.163.com/15/1018/11/B674F41400011229.html#f=resyswwwrank

獲取了鏈接地址后,就開始到網(wǎng)頁(yè)中扒取具體的新聞標(biāo)題和內(nèi)容了围辙,并且要插入數(shù)據(jù)庫(kù)氨肌。

import java.sql.*;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.select.Elements;
public class getArtical {
    public static void main(String[] args) {
        Connection conn= null;
        PreparedStatement pstmt = null;
        ResultSet rs=null;
        try{
            Class.forName("com.mysql.jdbc.Driver");
            conn=DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/search?useUnicode=true&characterEncoding=utf-8","root","123456");
            pstmt=conn.prepareStatement("select url from geturl ");
            rs=pstmt.executeQuery();
            while(rs.next()){
                Document doc = Jsoup.connect(rs.getString("url")).get();
                Elements head=doc.select("h1");
                Elements pageContent=doc.select("p");
                String title=head.text();
                String content=pageContent.text();
                System.out.println(title);
                pstmt=conn.prepareStatement("insert into artical(title,content,url)values(?,?,?)");
                pstmt.setString(1,title);
                pstmt.setString(2,content);
                pstmt.setString(3,rs.getString("url"));
                pstmt.executeUpdate();
            }
        }catch(Exception e){
            System.out.print("錯(cuò)誤:"+e.getMessage());
        }


    }

}

運(yùn)行結(jié)果如下

廣州曬天價(jià)采購(gòu)預(yù)算:U盤千元 辦公室1平米140萬(wàn)
男子說(shuō)"他媽的"被起訴 法官引魯迅文章判其無(wú)罪
媒體揭少林師徒反目史:億元武校背后的權(quán)錢博弈

"海天盛筵"女主角涉賣淫被抓 曾被曝3天賺60萬(wàn)
海天盛筵外圍女涉嫌組織賣淫被抓 名企老總涉案
昆明航空多名空姐被惡搞塞進(jìn)行李架(圖)

以上兩段程序的運(yùn)行結(jié)果,行數(shù)還有很多酌畜,為了節(jié)省篇幅怎囚,我只截取了其中的一部分。這是因?yàn)椋侨【W(wǎng)頁(yè)內(nèi)容的輸出恳守,只是為了更方便的知道我們扒取網(wǎng)頁(yè)成功了考婴。
但不論是否輸出,對(duì)于搜索引擎的后續(xù)工作是沒有影響的催烘。
那么沥阱,現(xiàn)在網(wǎng)頁(yè)內(nèi)容已經(jīng)扒取完畢,接下來(lái)該做什么呢伊群?請(qǐng)見后續(xù)文章考杉,[搜索引擎——http://www.reibang.com/p/3e84e02626fd

此項(xiàng)目的完整代碼可以到我的github,search-engine進(jìn)行下載舰始。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末崇棠,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子丸卷,更是在濱河造成了極大的恐慌枕稀,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,734評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件谜嫉,死亡現(xiàn)場(chǎng)離奇詭異萎坷,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)沐兰,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,931評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門哆档,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人住闯,你說(shuō)我怎么就攤上這事虐呻。” “怎么了寞秃?”我有些...
    開封第一講書人閱讀 164,133評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)偶惠。 經(jīng)常有香客問我春寿,道長(zhǎng),這世上最難降的妖魔是什么忽孽? 我笑而不...
    開封第一講書人閱讀 58,532評(píng)論 1 293
  • 正文 為了忘掉前任绑改,我火速辦了婚禮,結(jié)果婚禮上兄一,老公的妹妹穿的比我還像新娘厘线。我一直安慰自己,他們只是感情好出革,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,585評(píng)論 6 392
  • 文/花漫 我一把揭開白布造壮。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪耳璧。 梳的紋絲不亂的頭發(fā)上成箫,一...
    開封第一講書人閱讀 51,462評(píng)論 1 302
  • 那天,我揣著相機(jī)與錄音旨枯,去河邊找鬼蹬昌。 笑死,一個(gè)胖子當(dāng)著我的面吹牛攀隔,可吹牛的內(nèi)容都是我干的皂贩。 我是一名探鬼主播,決...
    沈念sama閱讀 40,262評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼昆汹,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼明刷!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起筹煮,我...
    開封第一講書人閱讀 39,153評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤遮精,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后败潦,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體本冲,經(jīng)...
    沈念sama閱讀 45,587評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,792評(píng)論 3 336
  • 正文 我和宋清朗相戀三年劫扒,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了檬洞。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,919評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡沟饥,死狀恐怖添怔,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情贤旷,我是刑警寧澤广料,帶...
    沈念sama閱讀 35,635評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站幼驶,受9級(jí)特大地震影響艾杏,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜盅藻,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,237評(píng)論 3 329
  • 文/蒙蒙 一购桑、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧氏淑,春花似錦勃蜘、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,855評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春匀归,著一層夾襖步出監(jiān)牢的瞬間坑资,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,983評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工穆端, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留袱贮,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,048評(píng)論 3 370
  • 正文 我出身青樓体啰,卻偏偏與公主長(zhǎng)得像攒巍,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子荒勇,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,864評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容