位置: 编程技术 - 正文

Node.js 实现简单小说爬虫实例(nodejs实战教程)

编辑:rootadmin

推荐整理分享Node.js 实现简单小说爬虫实例(nodejs实战教程),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:node.js快速入门,node.js怎么用,nodejs实现简单的发布文章,nodejs实战教程,node.js怎么用,nodejs实战教程,nodejs实现简单的发布文章,node.js怎么用,内容如对您有帮助,希望把文章链接给更多的朋友!

最近因为剧荒,老大追了爱奇艺的一部网剧,由丁墨的同名小说《美人为馅》改编,目前已经放出两季,虽然整部剧槽点满满,但是老大看得不亦乐乎,并且在看完第二季之后跟我要小说资源,直接要奔原著去看结局……

随手搜了下,都是在线资源,下载的话需要登录,注册登录好麻烦,写个爬虫玩玩也好,于是动手用 node 写了一个,这里做下笔记

工作流程

获取 URLs 列表(请求资源 request模块) 根据 URLs 列表获取相关页面源码(可能遇到页面编码问题,iconv-lite模块) 源码解析,获取小说信息( cheerio模块) 保存小说信息到 Markdown 文件,并且加适当修饰以及章节信息(写文件 fs、同步请求资源 sync-request 模块) Markdown 转 PDF (使用 Pandoc 或者 Chrome 的打印功能)

获取 URLs

根据小说的导航页,获取小说所有章节的 URL,并且以 JSON 数组的方式存储。

首选通过 http.get() 方法获取页面源码 获取到源码,打印发现中文乱码,查看发现 charset = 'gbk',需要进行转码 使用 iconv-lite 模块进行转码,中文显示正常后开始解析源码,获取需要的 URL,为了更方便地解析,需要引进 cheerio 模块,cheerio 可以理解为运行在后台的 jQuery,用法与 jQuery 也十分相似,熟悉 jQuery 的同学可以很快的上手 将源码加载进 cheerio,分析了源码后得知所有章节信息都存于被 div 包裹的 a 标签中,通过 cheerio 取出符合条件的 a 标签组,进行遍历,获取章节的 title 和 URL,保存为对象,存进数组,(因为链接中存储的 URL 不完整,所以存储时需要补齐) 将对象数组序列化,写进 list.json 文件

获取的列表示例

获取数据

有了 URLs 列表,接下来的工作就很机械了,遍历 URLs 列表请求资源,获取源码,解析源码,获取小说,写文件,但是,因为最终将所有的章节保存入一个文件,要保证章节的顺序,因此写文件需要 同步操作,实际上,我在编码的时候所有的操作都改成了同步方式

获取源码

通过解析读取的 list.json 文件,获取到 URLs 列表,遍历列表获取资源,因为需要确保章节的顺序,所以这里引进 sync-request 模块进行同步 request 请求资源,请求资源后照例转码

Node.js 实现简单小说爬虫实例(nodejs实战教程)

解析源码,获取小说

还是通过 cheerio 模块获取小说内容,避免影响观感,写操作之前去除内容中的的 html 标签

保存小说

写操作也需要同步操作,因此使用了同步写函数 fs.writeFileSync() 和 同步添加函数 fs.appendFileSync(),第一次写使用写函数,之后的内容都是进行 append 操作,为了改善阅读体验,每个章节前添加标题

也可以在内容前添加 拍 [TOC],作为导航链接

Markdown 转 PDF

我将小说保存在 Markdown 文件中,为了提升阅读体验,可以将 Markdown 文件转换成 PDF 文件,目前我较为喜欢的两种方式,通过 Chrome 的打印功能 以及 pandoc 转换

Chrome 打印

SublimeText 有个插件 markdown preview ,可通过 Alt + m 快捷键在 Chrome 中预览 Markdown,在 Chrome 页面中右键,选择打印,调整好参数后,选择另存为 PDF,简单,粗暴,深得我心

打印效果:

pandoc 转换pandoc 是十分强大的文件格式转换工具,可以将 Markdown 文件转换成多种格式,今晚在 windows 下折腾了半天,始终检索不到 pdflatex,关于 pandoc,后面会专门写一篇总结。

PDF 已经发给老大了,现在正在看

关于python、node、爬虫

在之前很长的一段时间里,很想用 Python,很想写爬虫,更想用 Python 写爬虫,甚至成为了心里的一块执念,随着接触的知识更全面,执念也逐渐淡去,少了很多“想”,遇事想着多去动手,实践出真知。

标签: nodejs实战教程

本文链接地址:https://www.jiuchutong.com/biancheng/374088.html 转载请保留说明!

上一篇:Nodejs下DNS缓存问题浅析(nodejs ddd)

下一篇:node+experss实现爬取电影天堂爬虫(node网络爬虫)

  • 固定资产处置营业外收入和发票金额不一致
  • 业务招待费税前扣除标准是
  • 折旧费计算主要有几种方法?分别有什么特点?
  • 母公司出售子公司给另一家子公司
  • 政府补贴营业外收入所得税汇算清缴需要调增吗
  • 进口代收业务
  • 商业承兑汇票托收凭证怎么做分录
  • 总公司调到子公司
  • 已经给员工交了社保能退吗
  • 核销确实无法收回的应收账款后会影响资产负债率
  • 营业外收入做多了怎么办
  • 企业为员工提供住宿会计科目
  • 洒水车属于免税车辆吗?
  • 现金流量表根据什么原则编制
  • 有限责任公司向合伙企业投资
  • windows聚焦无法显示 为灰色
  • 什么叫盘活存量股票
  • 个体工商户投资金额填多少
  • 纳税人依法可以享受减免税待遇而没有享受的
  • 损益期末余额怎么算
  • 分期付款购买的商品
  • php面向对象面试题
  • 施工企业的收入和成本如何确认
  • 境外付款
  • vue2.0解决跨域问题
  • 西部大开发税收优惠政策是什么时候开始的?
  • vue docx-preview实现docx文件在线预览
  • arp-a命令怎么用
  • 工业企业采购商品过程中发生的进货费用
  • 税前扣除项目应遵循哪些原则
  • 物业管理服务小组职责
  • 企业有代扣代缴个税义务
  • 当月注销外管证个税账户也会注销吗
  • 现代服务增值税纳税义务发生时间
  • 金税盘使用流程
  • 为公司垫付费用多久报销
  • 收到质量赔款涉税处理
  • 开票有误重新开票怎么做分录
  • 小规模未开票收入超过30万如何申报
  • 如何办理出口收款凭证
  • 成本核算方法是资源到作业,作业到产品吗?
  • 一般纳税人购入商品会计分录
  • 车辆处置收入怎么交税
  • 企业取得的跨期业务
  • 在建工程物资属于存货吗
  • 凭证摘要写错了已结账了怎么办
  • 固定资产暂停使用申请怎么写
  • 交税务局的工会经费现金流
  • 公司试驾车怎么开票
  • 进项税额转出后续处理
  • 外商投资企业清算资金汇出环节,银行
  • 建筑业异地预缴税款最新规定
  • 油费可以进项抵税吗
  • 小规模纳税人销售自己使用过固定资产
  • 资产减值损失属于营业外支出吗
  • 资产负债表日指的是什么
  • 事业单位会计岗位属于哪一类
  • 建造固定资产的账务处理(出包方式)
  • sqlserver允许一列列值重复
  • linux命令提示符不见了
  • 老毛桃U盘装系统综合教程
  • linux操作系统的安装步骤
  • 怎样一键清空
  • windows电脑图片传到iphone
  • make:arm-linux- conmand not found错误处理探讨
  • 怎么创建windows虚拟机
  • win8笔记本无法更新正在撤销更改
  • 微软商店更新错误
  • win7如何查询电脑使用记录
  • 在linux操作系统中把外部设备当作文件统一管理
  • javascript解析器
  • 制作网站页面
  • 安卓开发者有多少
  • javascript中cookie
  • javascript主要学什么
  • shell生成excel文件
  • jquery.validator
  • 常规巡察和专项巡察相结合
  • 郑州地铁客服热线电话
  • 江苏几个地级市几个县级市
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设