Python爬虫实战(三) 免登录爬取东野圭吾超话——看看你喜欢的书上榜没?

2023-12-05 05:08

本文主要是介绍Python爬虫实战(三) 免登录爬取东野圭吾超话——看看你喜欢的书上榜没?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        微博爬虫可以不借助selenium,直接用Chrome下的手机端模式打开,找到其封装的json数据,即可爬取,具体步骤如下。

分析过程

        以东野圭吾超话为例,网址为微博超话。进入页面后,使用Chrome浏览器的检查功能,打开手机端模式如下:

在这里插入图片描述
        刷新界面,进行抓包,可发现数据的封装地址。
在这里插入图片描述
接下来,我们分析一下翻页原理,向下滑动界面,对比两者的URL
在这里插入图片描述
在这里插入图片描述
不难发现,只有since_id不一样。那就找到第一条url的json数据,看看有没有第二条url的since_id。经过分析发现,第二条的url的since_id在第一条url的PageInfo下!这样,我们就可以翻页啦!
在这里插入图片描述

爬取代码:

微博反爬还是有点厉害的!一开始,我只用了一个用户代理,没爬到几条数据后就被检测出来了。然后,换了随机用户代理后,IP地址又被封了。所以,还是老老实实构建代理池弄吧。(IP都是网上找的免费可用的,自己可以先用代码检测一下活性)

import requests
import json
import re
import os
import time,random
os.chdir('C:/Users/dell/Desktop')
import pandas as pd
from w3lib.html import remove_tags
base_url='''
https://m.weibo.cn/api/container/getIndex?containerid=1008082daf12cb79491a80017ae2546cc6f49f_-_feed&luicode=10000011
&lfid=100103type%3D533%26t%3D10%26q%3D%E4%B8%9C%E9%87%8E%E5%9C%AD%E5%90%BE&since_id=4487749686029266
'''
head_list=["Opera/9.80 (X11; Linux i686; Ubuntu/14.10) Presto/2.12.388 Version/12.16","Opera/9.80 (Windows NT 6.0) Presto/2.12.388 Version/12.14","Mozilla/5.0 (Windows NT 6.0; rv:2.0) Gecko/20100101 Firefox/4.0 Opera 12.14","Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.0) Opera 12.14","Opera/12.80 (Windows NT 5.1; U; en) Presto/2.10.289 Version/12.02",]
ip=['114.101.42.16:65309','220.179.255.7:8118','103.44.145.182:8080','115.223.7.110:80']
proxy={'http':random.choice(ip)}
header={'user-agent':random.choice(head_list)}
pat='since_id=(.*)'
inf=[]
for page in range(1,300):try:r=requests.get(base_url,headers=header,proxies=proxy)df=json.loads(r.text)since_id=df.get('data').get('pageInfo').get('since_id')data=df.get('data').get('cards')[0].get('card_group')for item in data:send_time=item.get('mblog').get('created_at')content=remove_tags(item.get('mblog').get('text'))inf.append([send_time,content])base_url=re.sub(pat,'since_id='+str(since_id),base_url)print('第{}页写入完毕'.format(page))time.sleep(random.randint(3,5))except:print('未爬到数据')
inf1=pd.DataFrame(inf,columns=['发布时间','内容'])
inf1.to_csv('daily_comment.csv',index=False,encoding='gb18030')
数据可视化

时间范围:2019年3月——2020年3月
计数方式:单条微博提到书籍名则计数一次,重复则按一条来算
1. 统计各类书籍总讨论次数
在这里插入图片描述
《白夜行》一骑绝尘,在一年中书友们讨论了181次;紧跟其后的则是《恶意》,共讨论了140次;第三名则是《信》,共讨论了90次。由此可见,这三本在书迷中的人气较高哦,安利给大家~

2. 按月份统计书籍讨论次数
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
从上图来看,《白夜行》依旧是东野粉的至爱呀,一年中有半年的时间占讨论次数榜首;《恶意》也紧跟其后,分别在1月和8月占据榜首;《信》在2月和9月占据榜首;《祈祷落幕时》在4月讨论次数最多,《沉默的巡游》是最近才出的新书,故占据了3月的榜首。

3. 统计书中人物的讨论次数
在这里插入图片描述
亮司和雪穗是《白夜行》的男女主角,石神是《嫌疑人X的献身》的男主角。而加贺和汤川则是东野圭吾笔下两个十分有特色的人物。加贺是一名警官,既有缜密的推理能力,心中又有一份温柔,正因为如此,所以深受大家喜爱。而汤川是一名物理学家,时常帮助警方处理案件。相对加贺而言,看待事物更加理性、客观,也深受书迷们的追捧。

4. 讨论词云图
在这里插入图片描述
从词语图来看,“嫌疑人”、“杀人”、“系列”、"凶手"等词语出现频率较高,毕竟东叔是推理小说家嘛!

5.书籍关联图

对微博文字内容进行分词,并构建共现字典,查看哪些书最容易一起被提到。使用Gephi进行可视化,得到下图:
在这里插入图片描述

上图的线条越粗,说明两本书的关联程度越高!即微博里的用户经常一起提到这两本书。《白夜行》和《恶意》是经常一起被提到!此外,《白夜行》还和《幻夜》一起被提到的(也难怪《幻夜》是《白夜行》的姊妹篇!)

这篇关于Python爬虫实战(三) 免登录爬取东野圭吾超话——看看你喜欢的书上榜没?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/456267

相关文章

Python中使用正则表达式精准匹配IP地址的案例

《Python中使用正则表达式精准匹配IP地址的案例》Python的正则表达式(re模块)是完成这个任务的利器,但你知道怎么写才能准确匹配各种合法的IP地址吗,今天我们就来详细探讨这个问题,感兴趣的朋... 目录为什么需要IP正则表达式?IP地址的基本结构基础正则表达式写法精确匹配0-255的数字验证IP地

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求

Python 迭代器和生成器概念及场景分析

《Python迭代器和生成器概念及场景分析》yield是Python中实现惰性计算和协程的核心工具,结合send()、throw()、close()等方法,能够构建高效、灵活的数据流和控制流模型,这... 目录迭代器的介绍自定义迭代器省略的迭代器生产器的介绍yield的普通用法yield的高级用法yidle

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用

Python基础语法中defaultdict的使用小结

《Python基础语法中defaultdict的使用小结》Python的defaultdict是collections模块中提供的一种特殊的字典类型,它与普通的字典(dict)有着相似的功能,本文主要... 目录示例1示例2python的defaultdict是collections模块中提供的一种特殊的字

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

基于Python实现高效PPT转图片工具

《基于Python实现高效PPT转图片工具》在日常工作中,PPT是我们常用的演示工具,但有时候我们需要将PPT的内容提取为图片格式以便于展示或保存,所以本文将用Python实现PPT转PNG工具,希望... 目录1. 概述2. 功能使用2.1 安装依赖2.2 使用步骤2.3 代码实现2.4 GUI界面3.效

Python获取C++中返回的char*字段的两种思路

《Python获取C++中返回的char*字段的两种思路》有时候需要获取C++函数中返回来的不定长的char*字符串,本文小编为大家找到了两种解决问题的思路,感兴趣的小伙伴可以跟随小编一起学习一下... 有时候需要获取C++函数中返回来的不定长的char*字符串,目前我找到两种解决问题的思路,具体实现如下:

python连接本地SQL server详细图文教程

《python连接本地SQLserver详细图文教程》在数据分析领域,经常需要从数据库中获取数据进行分析和处理,下面:本文主要介绍python连接本地SQLserver的相关资料,文中通过代码... 目录一.设置本地账号1.新建用户2.开启双重验证3,开启TCP/IP本地服务二js.python连接实例1.

基于Python和MoviePy实现照片管理和视频合成工具

《基于Python和MoviePy实现照片管理和视频合成工具》在这篇博客中,我们将详细剖析一个基于Python的图形界面应用程序,该程序使用wxPython构建用户界面,并结合MoviePy、Pill... 目录引言项目概述代码结构分析1. 导入和依赖2. 主类:PhotoManager初始化方法:__in