零基础学Python网络爬虫案例实战 全流程详解 高级进阶篇
零基础学Python网络爬虫案例实战 全流程详解 入门与提高篇
零基础学Python网络爬虫案例实战 全流程详解 高级进阶篇
编辑推荐
本书讲解了Python爬虫技术的高级进阶知识,帮助有一定爬虫基础的读者进一步提高爬虫技术。本书详解了突破反爬机制的常用手段以及Scrapy和Flask两大商业级框架,并囊括了30个爬虫实战案例,包含2800余行代码,涉及10个网站和App的数据爬取。
内容简介
网络爬虫是当今获取数据不可或缺的重要手段。本书讲解了Python爬虫的进阶理论与技术,帮助读者提升实战水平。
全书共7章。
第1~3章为常见反爬机制的应对手段,主要内容包括Cookie模拟登录、多种类型的验证码识别、Ajax动态请求破解。
第4章为手机App内容爬取。
第5章和第6章为Scrapy爬虫框架应用。
第7章为爬虫云服务器部署。
本书适合有一定Python网络爬虫编程基础的学生或相关从业人员,以及想要在Python网络爬虫开发、不同类型的反爬机制应对、爬虫框架开发、爬虫云端部署等方面进阶提高的读者。
作者简介
王宇韬
(CFA、FRM、AQF)
华能贵诚信托金融科技实验室发起人,宾夕法尼亚大学硕士,上海交通大学学士,曾在剑桥大学交流学习,两年内通过CFA 3级、FRM 2级、AQF。在华能贵诚信托自主研发了舆情监控系统、资金雷达、流程自动化AI系统、机器视频面试系统等;专注于科技在金融领域的应用,编著有《Python金融大数据挖掘与分析全流程详解》和《Python大数据分析与机器学习商业案例实战》。
吴子湛
毕业于合肥工业大学计算机学院,就职于南京市秦淮区大数据中心,拥有多年IT
研发经验,擅长大数据分析与挖掘。
目录
前言
本书学习资源
第1章 Cookie模拟登录
1.1 Cookie模拟登录的原理 11
1.1.1 客户端与服务端 11
1.1.2 HTTP的无状态性 12
1.1.3 Cookie的含义与作用 13
1.1.4 Session的含义与作用 16
1.1.5 Cookie与Session的交互 17
1.2 案例实战1:模拟登录淘宝并爬取数据 20
1.2.1 获取Cookie模拟登录淘宝 20
1.2.2 爬取淘宝商品数据 25
1.3 案例实战2:模拟登录新浪微博并爬取数据 29
1.3.1 获取Cookie模拟登录新浪微博 30
1.3.2 爬取新浪微博热搜榜信息 34
★ 课后习题 38
第2章 验证码反爬的应对
2.1 图像验证码 39
2.1.1 超级鹰平台注册 40
2.1.2 超级鹰Python接口的使用 41
2.1.3 案例实战:英文验证码和中文验证码识别 46
2.2 计算题验证码 51
2.3 滑块验证码 54
2.4 滑动拼图验证码 57
2.4.1 初级版滑动拼图验证码 59
2.4.2 高级版滑动拼图验证码 63
2.5 点选验证码 68
2.5.1 本地网页识别 69
2.5.2 bilibili点选验证码识别初探 75
2.5.3 bilibili点选验证码识别升级:无限尝试版 80
★ 课后习题 85
第3章 Ajax动态请求破解
3.1 Ajax简介 86
3.1.1 不同的网页翻页方式的对比 86
3.1.2 Ajax的基本概念与工作原理 88
3.2 案例实战1:爬取开源中国博客频道 89
3.2.1 分析Ajax请求 89
3.2.2 爬取单页博客 92
3.2.3 爬取多页博客 96
3.3 案例实战2:爬取新浪微博 98
3.3.1 模拟登录新浪微博 100
3.3.2 分析单个微博页面 101
3.3.3 破解Ajax请求爬取多页 103
★ 课后习题 108
第4章 手机App内容爬取
4.1 相关软件安装 109
4.1.1 安装夜神模拟器 110
4.1.2 安装Node.js 111
4.1.3 安装JDK 113
4.1.4 安装Android Studio 117
4.1.5 安装Appium 118
4.1.6 安装Appium-Python-Client库 118
4.2 手机模拟操作初步尝试 119
4.2.1 用Android Studio连接夜神模拟器 119
4.2.2 用Python连接微信App 121
4.3 Appium基本操作与进阶操作 123
4.3.1 Appium基本操作 123
4.3.2 Appium进阶操作 126
4.4 案例实战:爬取微信朋友圈内容 132
4.4.1 获取微信朋友圈页面源代码 133
4.4.2 提取微信朋友圈内容 135
4.5 多开模拟器打开多个微信 138
4.5.1 多开模拟器 138
4.5.2 用Appium连接多个模拟器 139
★ 课后习题 143
第5章 Scrapy爬虫框架
5.1 Scrapy框架基础 144
5.1.1 Scrapy的安装方法 144
5.1.2 Scrapy的整体架构 146
5.1.3 Scrapy的常用指令 148
5.2 案例实战1:百度新闻爬取 156
5.2.1 Robots协议破解 157
5.2.2 User-Agent设置 158
5.2.3 百度新闻标题爬取 159
5.3 案例实战2:新浪新闻爬取 160
5.3.1 实体文件设置 161
5.3.2 新浪新闻爬取:爬取一条新闻 162
5.3.3 新浪新闻爬取:爬取多条新闻 166
5.3.4 新浪新闻爬取:生成文本文件报告 167
5.4 案例实战3:豆瓣电影海报图片爬取 170
5.4.1 用常规方法爬取 170
5.4.2 用Scrapy爬取 171
5.5 知识拓展:Python类的相关知识 176
5.5.1 类和对象的概念 176
5.5.2 类名、属性和方法 176
5.5.3 类的进阶知识 179
★ 课后习题 182
第6章 Scrapy应对反爬
6.1 中间件技术概述 183
6.1.1 下载器中间件 184
6.1.2 爬虫中间件 184
6.2 Scrapy IP代理:爬取搜狗图片 185
6.2.1 用Requests库批量下载图片 186
6.2.2 用Scrapy框架批量下载图片 198
6.3 Scrapy Cookie:模拟登录淘宝 202
6.3.1 在中间件文件中添加Cookie 202
6.3.2 编写并运行爬虫文件:爬取淘宝网页 204
6.4 Scrapy Selenium库:爬取财经新闻 206
6.4.1 在中间件文件中添加Selenium库 207
6.4.2 编写并运行爬虫文件:爬取新闻信息 209
★ 课后习题 214
第7章 爬虫云服务器部署
7.1 HTML网页制作进阶 215
7.1.1 表格 217
7.1.2 列表 218
7.1.3 样式设计 220
7.1.4 背景设置 228
7.2 Flask Web编程基础 232
7.2.1 Flask入门 232
7.2.2 用render_template()函数渲染页面 237
7.2.3 用Flask连接数据库 242
7.3 Flask Web编程实战 247
7.3.1 展示单家公司的数据 247
7.3.2 展示多家公司的数据 252
7.3.3 展示舆情评分 255
7.3.4 只展示当天新闻 257
7.3.5 只展示负面新闻 258
7.4 云服务器的购买和登录 261
7.5 程序云端部署及网站搭建 265
7.5.1 搭建程序的运行环境 265
7.5.2 程序24小时运行及Flask项目部署 266
7.5.3 域名申请和使用 267
★ 课后习题 270
前 言
笔者编写的《Python金融大数据挖掘与分析全流程详解》于2019年出版面市后,陆续有不少读者表示对该书的爬虫部分非常感兴趣,想做进一步的学习。笔者由此萌生了一个想法:专门针对Python爬虫技术编写一套书籍,在保留之前核心内容的基础上,新增更多实战案例,方便读者在练中学,并体会Python爬虫在实战中的应用。
书稿编写完成后,为了更好地满足不同水平读者的需求,方便他们根据自身情况更灵活地学习,笔者决定将书稿分为两册出版:册为《零基础学Python网络爬虫案例实战全流程详解(入门与提高篇)》,主要针对编程零基础的读者;第二册为《零基础学Python网络爬虫案例实战全流程详解(高级进阶篇)》,主要针对有一定Python爬虫编程基础并且需要进阶提高的读者。
本书为《零基础学Python网络爬虫案例实战全流程详解(高级进阶篇)》,分7章讲解了Python爬虫的进阶理论与技术,包括常见反爬机制的应对手段、手机App内容爬取、Scrapy爬虫框架应用、爬虫云服务器部署等。
第1章主要讲解如何通过Cookie模拟登录网站并爬取数据。首先介绍Cookie模拟登录的原理,然后通过模拟登录淘宝爬取商品数据、模拟登录新浪微博爬取热搜榜信息这两个实战案例来巩固所学。
相关文章:
零基础学Python网络爬虫案例实战 全流程详解 高级进阶篇
零基础学Python网络爬虫案例实战 全流程详解 入门与提高篇 零基础学Python网络爬虫案例实战 全流程详解 高级进阶篇 编辑推荐 本书讲解了Python爬虫技术的高级进阶知识,帮助有一定爬虫基础的读者进一步提高爬虫技术。本书详解了突破反爬机制的常用手段以及Scrapy和…...
第十二届“中关村青联杯”全国研究生数学建模竞赛-A题:水面舰艇编队防空和信息化战争评估模型(续)(附MATLAB代码实现)
目录 5.3.3 问题三的总结 5.4 问题四的模型建立与求解 5.4.1 问题分析 5.4.2 计算方位角和航向角...
bmp图像文件格式超详解
0 BMP简介 BMP(Bitmap-File)图形文件,又叫位图文件,是Windows采用的图形文件格式,在Windows环境下运行的所有图像处理软件都支持BMP图像文件格式。Windows系统内部各图像绘制操作都是以BMP为基础的。一个BMP文件由四部分组成: B…...
Unity Meta Quest 一体机开发(十三):【手势追踪】自定义交互事件 EventWrapper
文章目录 📕教程说明📕交互事件概述📕自定义交互逻辑⭐方法一:Inspector 面板赋值⭐方法二:纯代码处理 此教程相关的详细教案,文档,思维导图和工程文件会放入 Spatial XR 社区。这是一个高质量…...
13、Redis高频面试题
1、项目中为什么用Redis 我们项目中之所以选择Redis,主要是因为Redis有下面这些优点: 操作速度快:Redis的数据都保存在内存中,相比于其它硬盘类的存储,速度要快很多数据类型丰富:Redis支持 string&#x…...
Koa学习笔记
1、npm 初始化 npm init -y生成 package.json 文件,记录项目的依赖2、git 初始化 git init生成 .git 隐藏文件夹,.git 的本地仓库创建 .gitignore 文件,添加不提交文件的名称3、创建 ReadMe.md 文件 记录项目笔记4、搭建项目 安装 Koa 框架npm install koa5、编写最基本的…...
HiDataPlus 3.3.2-005 搭建(个人的一点心得体会 x86 平台)
HDP 集群搭建 前置安装 yum -y install createrepo yum install -y lrzsz yum install -y wget yum install -y vim修改当前集群机器的主机名 hostnamectl set-hostname XXX 这里的 XXX 就是要设置的当前机器的主机名称。主机名称是集群唯一的,一定不要重复&am…...
【PHP】PHP实现与硬件串口交互,接收硬件发送的实时数据
一、前言 目的:借助虚拟串口软件(VSPD)模拟硬件串口发送数据,使用PHP语言实现接收硬件发送的数据。 我这里的需求是连接天平,把天平的称量数据实时的传送到PHP使用。 使用工具:vspd串口调试工具 使用语…...
HNU-数据库系统-作业
数据库系统-作业 计科210X 甘晴void 202108010XXX 第一章作业 10.09 1.(名词解释)试述数据、数据库、数据库管理系统、数据库系统的概念。 数据,是描述事物的符号记录。 数据库(DB),是长期存储在计算机内、有组织、可共享的大量…...
Python基础知识:整理10 异常相关知识
1 异常的捕获 1.1 基础写法 """基本语法:try:可能发生错误的代码except:如果出现异常,将执行的代码""" try:fr open("D:/abc.txt", "r", encoding"utf-8") except:print("出现异常…...
golang并发安全-select
前面说了golang的channel, 今天我们看看golang select 是怎么实现的。 数据结构 type scase struct {c *hchan // chanelem unsafe.Pointer // 数据 } select 非默认的case 中都是处理channel 的 接受和发送,所有scase 结构体中c是用来存储…...
微软Visual Studio产品之Visual C++编程进阶——一维数组(画画版)
我是荔园微风,作为一名在IT界整整25年的老兵,看到不少初学者在学习编程语言的过程中如此的痛苦,我决定做点什么,我小时候喜欢看小人书(连环画),在那个没有电视、没有手机的年代,这是…...
Moonbeam生态项目分析 — — 下一代DeFi协议HydraDX
作者:David 概览 HydraDX是一个基于Substrate区块链框架构建的DeFi协议,旨在为波卡带来大量流动性。HydraDX的特色服务,HydraDX Omnipool,是一种创新的自动化做市商(AMM),通过将所有资产组合在…...
Spark九:Spark调优之Shuffle调优
Spark shuffle调优方法 map端和reduce端缓存大小设置,reduce端重试次数和等待时间间隔,以及bypass设置 学习资料:https://mp.weixin.qq.com/s/caCk3mM5iXy0FaXCLkDwYQ 一、map和reduce端缓冲区大小 1.1 map端 在Spark任务运行过程中&…...
linux c多线程优先级
在 Linux 系统中,可以使用 pthread_setschedparam 函数来设置线程的优先级。该函数需要传入一个指向 pthread_t 类型的线程 ID,以及一个指向 struct sched_param 类型的结构体对象。struct sched_param 结构体包含了线程的优先级信息。 下面是一个示例代…...
Redis在项目开发中的应用
Spring Boot集成Redis构建博客应用 在这个示例中,我们将展示如何使用Spring Boot和Redis构建一个简单的博客应用,包括文章发布、点赞和评论功能。 1. 添加依赖 首先,我们需要在pom.xml文件中添加Spring Boot和Redis的依赖项。 <!-- Sp…...
mapper向mapper.xml传参中文时的乱码问题
1.起因: 在idea中进行模糊查询传参时,发现在idea中查中文查不出记录,在navicate中可以查出来。 2.猜测: 1.idea中的编码问题导致的乱码。 2.idea和navicate的编码一致性导致的乱码。 3.mapper向mapper.xml传参后出现乱码。 3.解…...
基于Docker官方php:7.1.33-fpm镜像构建支持67个常见模组的php7.1.33镜像
实践说明:基于RHEL7(CentOS7.9)部署docker环境(23.0.1、24.0.2),所构建的php7.1.33镜像应用于RHEL7-9(如AlmaLinux9.1),但因为docker的特性,适用场景是不限于此的。 文档形成时期:2017-2023年 因系统或软件版本不同&am…...
Type-C PD充电器受电端sink诱骗取电汇总:小家电应用5V9V12V15V20V28V
小家电产品、美容产品、电动产品等升级采用Type-C接口,在Type-C接口上使用Type-C取电芯片,即可使用快速充电器的5V、9V、12V、15V、20V供电,无需再配充电器,各类品牌的充电器都可以支持。目前充电器常见的USB-PD功率为:…...
禁用code server docker容器中的工作区信任提示
VSCode 添加受限模式,主要是防止自动运行代码的,比如在vscode配置的task和launch参数是可以运行自定义代码的。如果用VScode打开未知的工程文件就有可能直接运行恶意代码。 但是当我们的实验基础模板文件可控的情况下,要想禁用code server do…...
Prompt Tuning、P-Tuning、Prefix Tuning的区别
一、Prompt Tuning、P-Tuning、Prefix Tuning的区别 1. Prompt Tuning(提示调优) 核心思想:固定预训练模型参数,仅学习额外的连续提示向量(通常是嵌入层的一部分)。实现方式:在输入文本前添加可训练的连续向量(软提示),模型只更新这些提示参数。优势:参数量少(仅提…...
golang循环变量捕获问题
在 Go 语言中,当在循环中启动协程(goroutine)时,如果在协程闭包中直接引用循环变量,可能会遇到一个常见的陷阱 - 循环变量捕获问题。让我详细解释一下: 问题背景 看这个代码片段: fo…...
【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 初始化服务器)
服务端执行命令请求的过程 【专栏简介】【技术大纲】【专栏目标】【目标人群】1. Redis爱好者与社区成员2. 后端开发和系统架构师3. 计算机专业的本科生及研究生 初始化服务器1. 初始化服务器状态结构初始化RedisServer变量 2. 加载相关系统配置和用户配置参数定制化配置参数案…...
LLM基础1_语言模型如何处理文本
基于GitHub项目:https://github.com/datawhalechina/llms-from-scratch-cn 工具介绍 tiktoken:OpenAI开发的专业"分词器" torch:Facebook开发的强力计算引擎,相当于超级计算器 理解词嵌入:给词语画"…...
汇编常见指令
汇编常见指令 一、数据传送指令 指令功能示例说明MOV数据传送MOV EAX, 10将立即数 10 送入 EAXMOV [EBX], EAX将 EAX 值存入 EBX 指向的内存LEA加载有效地址LEA EAX, [EBX4]将 EBX4 的地址存入 EAX(不访问内存)XCHG交换数据XCHG EAX, EBX交换 EAX 和 EB…...
【论文阅读28】-CNN-BiLSTM-Attention-(2024)
本文把滑坡位移序列拆开、筛优质因子,再用 CNN-BiLSTM-Attention 来动态预测每个子序列,最后重构出总位移,预测效果超越传统模型。 文章目录 1 引言2 方法2.1 位移时间序列加性模型2.2 变分模态分解 (VMD) 具体步骤2.3.1 样本熵(S…...
USB Over IP专用硬件的5个特点
USB over IP技术通过将USB协议数据封装在标准TCP/IP网络数据包中,从根本上改变了USB连接。这允许客户端通过局域网或广域网远程访问和控制物理连接到服务器的USB设备(如专用硬件设备),从而消除了直接物理连接的需要。USB over IP的…...
C#中的CLR属性、依赖属性与附加属性
CLR属性的主要特征 封装性: 隐藏字段的实现细节 提供对字段的受控访问 访问控制: 可单独设置get/set访问器的可见性 可创建只读或只写属性 计算属性: 可以在getter中执行计算逻辑 不需要直接对应一个字段 验证逻辑: 可以…...
【从零学习JVM|第三篇】类的生命周期(高频面试题)
前言: 在Java编程中,类的生命周期是指类从被加载到内存中开始,到被卸载出内存为止的整个过程。了解类的生命周期对于理解Java程序的运行机制以及性能优化非常重要。本文会深入探寻类的生命周期,让读者对此有深刻印象。 目录 …...
RabbitMQ入门4.1.0版本(基于java、SpringBoot操作)
RabbitMQ 一、RabbitMQ概述 RabbitMQ RabbitMQ最初由LShift和CohesiveFT于2007年开发,后来由Pivotal Software Inc.(现为VMware子公司)接管。RabbitMQ 是一个开源的消息代理和队列服务器,用 Erlang 语言编写。广泛应用于各种分布…...
