博客
关于我
nodejs http小爬虫
阅读量:793 次
发布时间:2023-02-16

本文共 2073 字,大约阅读时间需要 6 分钟。

Node.js 小爬虫实践

爬虫是网络世界中的“探索者”,通过抓取网页代码获取各种数据。Node.js 生态中,利用 http 模块可以轻松实现简单的爬虫功能。

示例一:基础爬虫

var http = require('http');var url = "http://www.imooc.com/learn/348";http.get(url, function(res) {    var html = '';    res.on('data', function(data) {        html += data;    });    res.on('end', function() {        console.log(html);    });}).on('error', function() {    console.log('请求出错');});

将代码保存为 imooc-crawler.js,运行命令:

node imooc-crawler.js

注意:确保脚本路径正确。

示例二:增强功能

为了更好地抓取结构化数据,我们需要 cheerio 库,它类似于 jQuery,支持 DOM 操作。

安装依赖:

npm install cheerio

完成后,修改爬虫代码:

var http = require('http');var cheerio = require('cheerio');var url = "http://www.imooc.com/learn/348";function filterChapters(html) {    var $ = cheerio.load(html);    var courseData = [];        $('.learnchapter').each(function(item) {        var chapter = $(this);        var chapterTitle = chapter.find('strong').text();        var videos = chapter.find('.video').children('li');                var chapterData = {            title: chapterTitle,            videos: []        };                videos.each(function(item) {            var video = $(this).find('.studyvideo');            var videoTitle = video.text();            var id = video.attr('href').split('video/')[1];                        chapterData.videos.push({                title: videoTitle,                id: id            });        });                courseData.push(chapterData);    });        return courseData;}function printCourseInfo(courseData) {    courseData.forEach(function(item) {        console.log(item.title);        item.videos.forEach(function(video) {            console.log(' [' + video.id + '] ' + video.title);        });    });}http.get(url, function(res) {    var html = '';    res.on('data', function(data) {        html += data;    });    res.on('end', function() {        var courseData = filterChapters(html);        printCourseInfo(courseData);    });}).on('error', function() {    console.log('请求出错');});

将代码保存为 crawler.js,运行命令:

node crawler.js

个人总结

本次实践主要体验了 Node.js 爬虫开发的基础流程。通过 cheerio 学习了如何操作 DOM 结构,掌握了爬取网页内容的基础方法。

转载地址:http://xvjfk.baihongyu.com/

你可能感兴趣的文章
NLP 模型中的偏差和公平性检测
查看>>
Vue3.0 性能提升主要是通过哪几方面体现的?
查看>>
NLP 项目:维基百科文章爬虫和分类【01】 - 语料库阅读器
查看>>
NLP_什么是统计语言模型_条件概率的链式法则_n元统计语言模型_马尔科夫链_数据稀疏(出现了词库中没有的词)_统计语言模型的平滑策略---人工智能工作笔记0035
查看>>
NLP三大特征抽取器:CNN、RNN与Transformer全面解析
查看>>
NLP学习笔记:使用 Python 进行NLTK
查看>>
NLP度量指标BELU真的完美么?
查看>>
NLP的不同研究领域和最新发展的概述
查看>>
NLP的神经网络训练的新模式
查看>>
NLP采用Bert进行简单文本情感分类
查看>>
NLP问答系统:使用 Deepset SQUAD 和 SQuAD v2 度量评估
查看>>
NLP项目:维基百科文章爬虫和分类【02】 - 语料库转换管道
查看>>
NLP:从头开始的文本矢量化方法
查看>>
NLP:使用 SciKit Learn 的文本矢量化方法
查看>>
nmap 使用方法详细介绍
查看>>
nmap使用
查看>>
Nmap扫描教程之Nmap基础知识
查看>>
nmap指纹识别要点以及又快又准之方法
查看>>
Nmap渗透测试指南之指纹识别与探测、伺机而动
查看>>
Nmap端口扫描工具Windows安装和命令大全(非常详细)零基础入门到精通,收藏这篇就够了
查看>>