nodejs 小爬蟲

編寫爬蟲示例:html

var http = require('http');
var cheerio = require('cheerio');

var url = 'http://www.cnblogs.com/tianxintian22/';

function filterblogs(html) {
    var $ = cheerio.load(html);

    var blogs = $('.day');

    // [{
    //     dayTitle: '',
    //    dayCont: {
    //        postId: '',
    //         postTitle: '',
    //         postCont: ''
    //    }
    // }]

    var blogDatas = [];

    blogs.each(function(item) {
        var blog = $(this);
        var dayTitle = blog.find('.dayTitle a').text();
        var blogData = {
            dayTitle: dayTitle,
            dayCont: []
        };

        var postId = blog.find('.postCon .c_b_p_desc a').attr('href').split('p/')[1].replace('.html', '');
        var postTitle = blog.find('.postTitle a').text();
        var postCont = blog.find('.postCon .c_b_p_desc').text();

        blogData.dayCont.push({
            postId: postId,
            postTitle: postTitle,
            postCont: postCont
        });

        blogDatas.push(blogData);
    })

    return blogDatas;

}

function printBlogInfo(blogDatas) {
    blogDatas.forEach(function(item) {
        var dayTitle = item.dayTitle;
        console.log(dayTitle + '\n');

        item.dayCont.forEach(function(blog){
            console.log('    【' + blog.postId + '】' + blog.postTitle +'\n');
            console.log('    ' + blog.postCont + '\n');
        });
    })
}

http.get(url, function (res) {
    var html = '';

    res.on('data', function(data) {
        html += data;
    });

    res.on('end', function() {
        var blogDatas =  filterblogs(html);
        printBlogInfo(blogDatas);
    });
}).on('error', function() {
    console.log('獲取博客數據出錯');
})
相關文章
相關標籤/搜索