猿人学第13题思路解题python

2024-01-28 02:40

本文主要是介绍猿人学第13题思路解题python,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第十三题:入门级cookie

这道配判定为非常简单的入门级题目着实让我这个爬虫刚入门的小白摸索了很久,主要就是sessionid与yuanrenxue_cookie的获取,话不多说,给你们分享一下我解题时的思路吧

1.解析过程

老规矩打开我们的f12开发人员调试工具

找到可疑的数据包,这里我们看到收到了三个名字为13的数据包,并且是对同一个地址请求的,这就非常可疑了

 观察cookie的变化

这里服务器给我们返回了一个sessionid这里就需要注意了,在完成题目过程中每个人的账号对应的数据不同,这里我们就需要使用requests.session保持长连接了,至于获得自己账号对应的sessionid这个我在请求表单里没找到是怎么登陆的,所以我在第一次请求13数据包时带入了浏览器中的cookie这个,获取属于我的一个sessionid,

 

 sessionid解决了,开始找除了hm开头的系统自带cookie跟数值为true不变的以外的cookie,还有一个yuanrenxue_cookie现在开始找

 由于chrome看不到第一个数据包的response数据我们进入袁仁学提供的采集分析工具简易postman对第一个13数据包https://match.yuanrenxue.com/match/13进行请求如图:

 这就很迷惑了粗开乱七八糟,近看直接有个cookie=,我们复制到调试工具控制台看看是什么东西,

 直接给我们了那就好办了,上代码:

import reimport jsonpath
import requestss = requests.session()
# 设置我们登陆账号时候的cookie一边一会请求时服务器返回我们对应的sessionid
s.headers={'cookie':'Hm_lvt_9bcbda9cbf86757998a2339a0437208e=1638093665,1638251207,1638258714; sessionid=yqizyrtq2vr54ktcqok7ka0v90n6fk59; Hm_lvt_c99546cf032aaa5a679230de9a95c7db=1638093654,1638251198,1638258654,1638275262; qpfccr=true; no-alert3=true; Hm_lpvt_c99546cf032aaa5a679230de9a95c7db=1638275298; yuanrenxue_cookie=1638275997|VUSdtXFR7nPfBIvRb4b8AUaaV5gWeJKTeOo3m04Zo29UoavnucDrQd54PXzMpuP0ksdCwznmASN0pCu90RxGJu4A9QvorinInwIwUkp5G2yg72eBdlvPBu8VNUsIPdLxDOrAOs0JQ6Cv5f1p3QhDEbnon'
}
# 获取我们的yuanrenxue_cookie
res = s.get("https://match.yuanrenxue.com/match/13")
coo_obj = res.content.decode()
# print(s.cookies)
print(s.headers)
# 使用正则把yuanrenxue_cookie里的括号引号迷惑项去掉
coo_obj=str(re.findall("cookie=(.*?)\+'", coo_obj)[0])
coo_obj=coo_obj.replace("('",'').replace("')",'').replace('+','')# .replace('yuanrenxue_cookie=','')
# 这里获取服务器返回我们的sessionid,便于一会组装我们的cookie
for v,k in s.cookies.iteritems():sessionid=v+'='+k
# 组装我们的cookie,作为请求头一会请求时使用
headers_ = {"User-Agent": "yuanrenxue.project",'cookie':coo_obj+';'+sessionid
}
# 设置请求头
s.headers=headers_
nums=0
print(s.headers)
# 开始获取数据
for i in range(1,6):num_data=s.get(f'https://match.yuanrenxue.com/api/match/13?page={i}').json()# print(num_data)# 使用jsonpath跨界点提取value的值num_l=jsonpath.jsonpath(num_data,'$..value')print(num_l)for num in num_l:print(num,end='\t')nums+=num
print('\n最终结果:',nums)

运行结果:

 作为刚入门的爬虫小白,这样就值得我欢呼一晚上了,一次程序的成功运行是背后无数次调试换来的,这次就到此结束了,感谢大家。不懂来评论🤭

 

这篇关于猿人学第13题思路解题python的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

浅析python如何去掉字符串中最后一个字符

《浅析python如何去掉字符串中最后一个字符》在Python中,字符串是不可变对象,因此无法直接修改原字符串,但可以通过生成新字符串的方式去掉最后一个字符,本文整理了三种高效方法,希望对大家有所帮助... 目录方法1:切片操作(最推荐)方法2:长度计算索引方法3:拼接剩余字符(不推荐,仅作演示)关键注意事

python版本切换工具pyenv的安装及用法

《python版本切换工具pyenv的安装及用法》Pyenv是管理Python版本的最佳工具之一,特别适合开发者和需要切换多个Python版本的用户,:本文主要介绍python版本切换工具pyen... 目录Pyenv 是什么?安装 Pyenv(MACOS)使用 Homebrew:配置 shell(zsh

Python自动化提取多个Word文档的文本

《Python自动化提取多个Word文档的文本》在日常工作和学习中,我们经常需要处理大量的Word文档,本文将深入探讨如何利用Python批量提取Word文档中的文本内容,帮助你解放生产力,感兴趣的小... 目录为什么需要批量提取Word文档文本批量提取Word文本的核心技术与工具安装 Spire.Doc

Python中Request的安装以及简单的使用方法图文教程

《Python中Request的安装以及简单的使用方法图文教程》python里的request库经常被用于进行网络爬虫,想要学习网络爬虫的同学必须得安装request这个第三方库,:本文主要介绍P... 目录1.Requests 安装cmd 窗口安装为pycharm安装在pycharm设置中为项目安装req

Python容器转换与共有函数举例详解

《Python容器转换与共有函数举例详解》Python容器是Python编程语言中非常基础且重要的概念,它们提供了数据的存储和组织方式,下面:本文主要介绍Python容器转换与共有函数的相关资料,... 目录python容器转换与共有函数详解一、容器类型概览二、容器类型转换1. 基本容器转换2. 高级转换示

使用Python将PDF表格自动提取并写入Word文档表格

《使用Python将PDF表格自动提取并写入Word文档表格》在实际办公与数据处理场景中,PDF文件里的表格往往无法直接复制到Word中,本文将介绍如何使用Python从PDF文件中提取表格数据,并将... 目录引言1. 加载 PDF 文件并准备 Word 文档2. 提取 PDF 表格并创建 Word 表格

使用Python实现局域网远程监控电脑屏幕的方法

《使用Python实现局域网远程监控电脑屏幕的方法》文章介绍了两种使用Python在局域网内实现远程监控电脑屏幕的方法,方法一使用mss和socket,方法二使用PyAutoGUI和Flask,每种方... 目录方法一:使用mss和socket实现屏幕共享服务端(被监控端)客户端(监控端)方法二:使用PyA

Python列表的创建与删除的操作指南

《Python列表的创建与删除的操作指南》列表(list)是Python中最常用、最灵活的内置数据结构之一,它支持动态扩容、混合类型、嵌套结构,几乎无处不在,但你真的会创建和删除列表吗,本文给大家介绍... 目录一、前言二、列表的创建方式1. 字面量语法(最常用)2. 使用list()构造器3. 列表推导式

Python使用Matplotlib和Seaborn绘制常用图表的技巧

《Python使用Matplotlib和Seaborn绘制常用图表的技巧》Python作为数据科学领域的明星语言,拥有强大且丰富的可视化库,其中最著名的莫过于Matplotlib和Seaborn,本篇... 目录1. 引言:数据可视化的力量2. 前置知识与环境准备2.1. 必备知识2.2. 安装所需库2.3

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度