利用Node寫一只小爬蟲爬一爬簡(jiǎn)書

不知不覺(jué)中經(jīng)過(guò)了1年了,這一年很快,也給我?guī)?lái)了很多轉(zhuǎn)變,這一年很累,也給我?guī)?lái)更多的知識(shí)。確實(shí)是很累呀,回想起每晚都在瞎搞搞,到兩三點(diǎn)精疲力盡的時(shí)候才去睡覺(jué),不過(guò)收獲也是巨大的,特別我的肚子也在不知不覺(jué)由腹肌變成了小肚子0 0,這是我很悲傷的一個(gè)故事。

好了,不扯了,這也不是我的風(fēng)格,今天給大家來(lái)點(diǎn)干貨,用用 Node.js (以下簡(jiǎn)稱 Node)來(lái)寫一寫小爬蟲來(lái)爬一爬簡(jiǎn)書。
首先來(lái)接受一下 Node

有看我博客的人也知道我是做 IOS 開(kāi)發(fā)的,但是為什么今天突然來(lái)寫 Node 呢?個(gè)人感覺(jué)吧,做什么開(kāi)發(fā)也好, 會(huì)點(diǎn)后臺(tái)也不會(huì)吃虧,畢竟網(wǎng)絡(luò)層的東西,多了解一下總是好的。說(shuō)不定以后自己要做個(gè)應(yīng)用什么的,起碼不會(huì)煩惱怎么做后臺(tái)吧。

那么寫爬蟲有什么好處呢,最起碼你寫的應(yīng)用需要的數(shù)據(jù)都能給你找回來(lái)吧,顯示個(gè)圖片什么的都是要數(shù)據(jù)的吧。那么用 Node 寫爬蟲的好處有什么呢,為什么要選擇 Node 呢?1.寫 Node 用的是 JavaScript,而 JavaScript 又是前端交互中經(jīng)常用到的,所以我們的學(xué)習(xí)開(kāi)發(fā)成本會(huì)降低,一方面練習(xí)了 JavaScript 語(yǔ)法,另一方面又能開(kāi)發(fā)后臺(tái),一舉兩得; 2.Node 的效率就是它的優(yōu)點(diǎn)了,由于Node的網(wǎng)絡(luò)是異步的,所以基本如同幾百個(gè)進(jìn)程并發(fā)一樣強(qiáng)大,內(nèi)存和CPU占用非常小。

那么說(shuō)了這么多,就是想告訴大家 Node 其實(shí)并沒(méi)有想象中那么差。好了,開(kāi)始我們今天的代碼了

首先我們要下載 Node 這個(gè)家伙了,下載完后只要簡(jiǎn)單的幾步安裝步驟就可以了。
那么我們還需要一個(gè)編輯器,當(dāng)然你也可以使用系統(tǒng)有的文本編輯器,但是在這里我個(gè)人來(lái)說(shuō)就選擇了 Atom 這款編輯器了,它一方面是高仿 sublineText ,只要熟悉 sublineText 的小伙伴就能很快上手了,另一方面是它的界面設(shè)計(jì)真心不錯(cuò),很吸引我,而且下載第三方包的工具是自帶的 apm(atom package manage) 很不錯(cuò)。

以下是我們需要爬的 html 結(jié)構(gòu)了

html 結(jié)構(gòu)

很亂的說(shuō)有木有,但是,相信大家,越難的東西才是我們應(yīng)該挑戰(zhàn)的嘛

1.創(chuàng)建 shujian.js 文件

2.引入我們需要的模塊

// 引入 node 的網(wǎng)絡(luò)模塊,這個(gè)模塊對(duì) node 來(lái)說(shuō)很重要
var http = require('http');
// 引入 `cheerio` 這個(gè)模塊,gitHub 上有介紹,它就是一個(gè)服務(wù)端的 JQuery  庫(kù)
var cheerio = require('cheerio');
// 以下這個(gè) url 是我個(gè)人主頁(yè)的,請(qǐng)使用的小伙伴換一下自己的主頁(yè)喔
var url =   'http://www.lxweimin.com/users/53fb509bd05c/latest_articles';

3.進(jìn)行一次 get的請(qǐng)求并對(duì)返回的 html 字符串進(jìn)行解析

http.get(url, function(res){
// 用于拼接接受到的 html 字符串
var html = '';
// on 是 node 的一個(gè)監(jiān)聽(tīng)事件
res.on('data', function(data) {
  html += data;
});

res.on('end', function() {
    // 解析 html 字符串的方法,返回文章數(shù)據(jù)的對(duì)象
     var articlesData = filterChapter(html);
    // 輸出這個(gè)對(duì)象的屬性
      printArticleInfo(articlesData);
  });
}).on('error', function(){
  console.log('個(gè)人主頁(yè)數(shù)據(jù)失敗');
});

4.解析 html 字符串的方法,返回文章數(shù)據(jù)的對(duì)象數(shù)組

function filterChapter(html) {
var $ = cheerio.load(html);
var articleList = $('.article-list').children('li');

// 創(chuàng)建一個(gè)空數(shù)組,用來(lái)裝載我們的文章對(duì)象
var articlesData = [];
articleList.each(function(item) {
  // 以下 JQ 的方法,相信會(huì)一點(diǎn) JQ 的人都能看懂啦,哈
  var article = $(this);
  var title = article.find('div').find('.title').find('a').text();
  var span =  article.find('div').find('div.list-footer').find('span');
  var loveCount = span.text();
  // .eq(i) 通過(guò)索引篩選匹配的元素。使用.eq(-i)就從最后一個(gè)元素向前數(shù)。
  var readCount = span.parent().find('a').eq(0).text();

 // 因?yàn)槲覀冎灰?喜歡的數(shù)量,并不想要這兩個(gè)字,所以用 JS 的方法把它去掉了,以下閱讀二字也是一樣的
  var loveNum = parseFloat(loveCount.substring(loveCount.search('喜歡') + '喜歡'.length)) ;
  var readNum = parseFloat(readCount.substring(readCount.search('閱讀') + '閱讀'.length));

 // 創(chuàng)建文章對(duì)象,JS 的對(duì)象確實(shí)跟 json 的很像呀
var articleData = {
    title : title, 
    love  : loveNum.toString(),
    readCount : readNum.toString()
};
  articlesData.push(articleData);
});
  return articlesData;
}

5.將這個(gè)文章數(shù)組內(nèi)的文章對(duì)象轉(zhuǎn)換成字符串輸出

function printArticleInfo(articlesData) {
console.log('止于浮水的簡(jiǎn)書 :\n');
articlesData.forEach(function(item) {
  var title = item.title;
  var loveCount = item.love;
  var readCount = item.readCount;
  console.log('《' + title + '》' + ' \n ' + '閱讀數(shù)為: ' + readCount  +   '\n'  + '喜歡數(shù)為:'  + loveCount + '\n');
  });
}

好了,寫了以上代碼,現(xiàn)在需要跑一跑了,打開(kāi)終端 輸入 node jianshu.js

以下就是我的輸出了

好了,到這里我們的 簡(jiǎn)書小爬蟲就完成了,根據(jù)這些方法,你可以去爬一些更多數(shù)據(jù)的網(wǎng)頁(yè),甚至可以寫更多更多的爬蟲同時(shí)去爬取數(shù)據(jù),讓你再創(chuàng)造 app 的時(shí)候不再懼怕沒(méi)有數(shù)據(jù)這塊了。當(dāng)然,這些數(shù)據(jù)需要一個(gè)數(shù)據(jù)庫(kù),這就是我以后要告訴小伙伴們的事情了。

@end

心如止水,奮力前行

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,885評(píng)論 6 541
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,312評(píng)論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事。” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 177,993評(píng)論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 63,667評(píng)論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,410評(píng)論 6 411
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 55,778評(píng)論 1 328
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,775評(píng)論 3 446
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 42,955評(píng)論 0 289
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,521評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,266評(píng)論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,468評(píng)論 1 374
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,998評(píng)論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,696評(píng)論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 35,095評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 36,385評(píng)論 1 294
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,193評(píng)論 3 398
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,431評(píng)論 2 378

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

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,714評(píng)論 25 708
  • 打球回來(lái)晚了^_^
    董淼閱讀 319評(píng)論 3 1
  • 牛魔王抬起一只手,撿掉一片落在女孩頭上的樹(shù)葉,牛魔王的手指碰到女孩的發(fā)梢,女孩輕輕顫抖了一下,牛魔王把那片樹(shù)葉遞到...
    王書著閱讀 452評(píng)論 0 0
  • 時(shí)間過(guò)得好快,這周幾乎什么都沒(méi)做就這么結(jié)束了。這周的前半段還在為一個(gè)工作上的問(wèn)題各種糾結(jié),接下來(lái)的幾天就完全無(wú)所事...
    大洪閱讀 539評(píng)論 1 1
  • 讀的什么書:《活得明白——生涯咨詢的十八個(gè)典型》 閱讀有效時(shí)間:半個(gè)小時(shí) 閱讀中遇到了什么困難:無(wú) 閱讀有什么收獲...
    wendyai閱讀 166評(píng)論 0 0