作者 | CriseLYJ

编译:机器之心(almosthuman2014)

作者收集了一些网站的登陆方式和爬虫程序,有的通过 selenium 登录,有的则通过抓包直接模拟登录。作者希望该项目能帮助初学者学习各大网站的模拟登陆方式,并爬取一些需要的数据。

作者表示模拟登陆基本采用直接登录或者使用 selenium+webdriver 的方式,有的网站直接登录难度很大,比如 qq 空间和 bilibili 等,采用 selenium 登录相对轻松一些。虽然在登录的时候采用的是 selenium,但为了效率,我们也可以在登录后维护得到的 cookie。登录后,我们就能调用 requests 或者 scrapy 等工具进行数据采集,这样数据采集的速度可以得到保证。

目前已经完成的网站有:

  • Facebook

  • 无需身份验证即可抓取 Twitter 前端 API

  • 微博网页版

  • 知乎

  • QQZone

  • CSDN

  • 淘宝

  • Baidu

  • 果壳

  • JingDong 模拟登录和自动申请京东试用

  • 163mail

  • 拉钩

  • Bilibili

  • 豆瓣

  • Baidu2

  • 猎聘网

  • 微信网页版登录并获取好友列表

  • Github

  • 爬取图虫相应的图片

如下所示,如果我们满足依赖项,那么就可以直接运行代码,它会在图虫网站中下载搜索到的图像。

如下所示为搜索「秋天」,并完成下载的图像:

每一个网站都会有对应的登录代码,有的还有数据的爬取代码。以豆瓣为例,主要的登录函数如下所示,它会获取验证码、处理验证码、返回登录数据完成登录,并最后保留 cookies。

def login():captcha, captcha_id = get_captcha()# 增加表数据datas[ captcha-solution ] = captchadatas[ captcha-id ] = captcha_idlogin_page = session.post(url, data=datas, headers=headers)page = login_page.textsoup = BeautifulSoup(page, "html.parser")result = soup.findAll( div , attrs={ class :  title })#进入豆瓣登陆后页面,打印热门内容for item in result:print(item.find( a ).get_text())# 保存 cookies 到文件,# 下次可以使用 cookie 直接登录,不需要输入账号和密码session.cookies.save()

其中获取并解决验证码的函数如下:

def get_captcha():获取验证码及其IDr = requests.post(url, data=datas, headers=headers)page = r.textsoup = BeautifulSoup(page, "html.parser")# 利用bs4获得验证码图片地址img_src = soup.find( img , { id :  captcha_image }).get( src )urlretrieve(img_src,  captcha.jpg )try:im = Image.open( captcha.jpg )im.show()im.close()except:print( 到本地目录打开captcha.jpg获取验证码 )finally:captcha = input( please input the captcha: )remove( captcha.jpg )captcha_id = soup.find(input , { type :  hidden ,  name :  captcha-id }).get( value )return captcha, captcha_id

当然这些都是简单的演示,在 GitHub 项目中可以找到更多的示例。此外,作者表明由于网站策略或者样式改变而导致代码失效,我们也可以提 Issue 或 Pull Requests。最后,该项目未来还会一直维护,很多东西哦也会慢慢改进,项目作者表明:

  • 项目写了一段时间后,发现代码风格、程序易用性、可扩展性、代码的可读性,都存在一定的问题,所以接下来最重要的是重构代码,让大家可以更容易的做出一些自己的小功能;

  • 如果读者觉得某个网站的登录很有代表性,可以在项目 issue 中提出;

  • 网站的登录机制有可能经常的变动,所以当现在的模拟的登录的规则不能使用的时候,请项目在 issue 中提出。

项目地址https://github.com/ape-python/awesome-python-login-model

分享或在看是对我最大的支持

用 Python 登录主流网站相关推荐

  1. python登录网站后爬取数据_用 Python 登录主流网站,我们的数据爬取少不了它

    不论是自然语言处理还是计算机视觉,做机器学习算法总会存在数据不足的情况,而这个时候就需要我们用爬虫获取一些额外数据.这个项目介绍了如何用 Python 登录各大网站,并用简单的爬虫获取一些有用数据,目 ...

  2. selenium验证码登录_用 Python 登录主流网站

    作者收集了一些网站的登陆方式和爬虫程序,有的通过 selenium 登录,有的则通过抓包直接模拟登录.作者希望该项目能帮助初学者学习各大网站的模拟登陆方式,并爬取一些需要的数据. Python人工智能 ...

  3. python登录网站后爬取数据_如何用 Python 登录主流网站,爬取一些需要的数据

    最近收集了一些网站的登陆方式和爬虫程序,有的通过 selenium 登录,有的则通过抓包直接模拟登录.作者希望该项目能帮助初学者学习各大网站的模拟登陆方式,并爬取一些需要的数据. 作者表示模拟登陆基本 ...

  4. selenium验证码登录_如何用 Python 登录主流网站,爬取一些需要的数据

    最近收集了一些网站的登陆方式和爬虫程序,有的通过 selenium 登录,有的则通过抓包直接模拟登录.作者希望该项目能帮助初学者学习各大网站的模拟登陆方式,并爬取一些需要的数据. 作者表示模拟登陆基本 ...

  5. 大写牛逼,用 Python 登录主流 24 个网站

    爬虫脚本是大家经常用到的,那就避开不了登录 这一关. 使用Python一般需要request库,补充 header 中的 post 要素,有些还会有 隐藏的 hidden 参数,可以通过浏览器 F12 ...

  6. python登录aspx网站

    1.安装模块 2.准备aspx登录页面 3.示例代码 1 #coding:utf-8 2 import re 3 from bs4 import BeautifulSoup 4 import gzip ...

  7. python爬虫登录网站_主流网站 Python 爬虫模拟登陆方法汇总

    欢迎关注我的公众号:高级农民工,博客:高级农民工,阅读体验更好. 摘要:介绍微信.知乎.新浪等一众主流网站的模拟登陆爬取方法. 网络上有形形色色的网站,不同类型的网站爬虫策略不同,难易程度也不一样.从 ...

  8. python登录网站 爬虫_Python爬虫如何使用Cookies登录网站

    最近搞到了一个学校教务系统可以查询全校成绩的账号,恰逢申请奖学金之际,就想用python写个脚本把年级里的绩点排名给爬下来,可是就在写登录的时候发现还是要处理验证码登录的问题,为了避免麻烦,就没使用类 ...

  9. JAVA爬需要账号登录的网_如何用 Python 爬取需要登录的网站?

    最近我必须执行一项从一个需要登录的网站上爬取一些网页的操作.它没有我想象中那么简单,因此我决定为它写一个辅助教程. 在本教程中,我们将从我们的bitbucket账户中爬取一个项目列表. 教程中的代码可 ...

最新文章

  1. zookeeper快速入门——部署
  2. Codeforces Round #665 (Div. 2) Maximum Distributed Tree(树上贪心)
  3. 作为一个部门经理,该如何带好下属?
  4. 【bzoj1511】[POI2006]OKR-Periods of Words KMP-next数组
  5. Field Service Center Customization
  6. JAVA 泛型与反射
  7. 【数据结构与算法】链表倒序输出算法
  8. Mobx | 强大的状态管理工具 | 可以用Mobx来替代掉redux
  9. 【刷算法】按照之字形打印二叉树
  10. birt中文手册在线_QGIS简体中文翻译现状
  11. Nhibernate HQL 匿名类(严格说是map的使用以及构造函数的使用
  12. vue.js原生组件化开发(一)——组件开发基础
  13. SQL Server 2019 Developer/Express 版本下载
  14. nested exception is java.lang.NumberFormatException: For input string: NaN
  15. 服务器内存只能显示4g_为什么安装4G内存显示只有2G或3G可用|Crucial(英睿达)
  16. 大厂团队Leader实战秘诀:工程师成长最重要的8项技能
  17. python模拟登录中国海洋大学教务系统(青果)- 爬取学期所有专业课至excel - 并进行课表排课(三)
  18. PTA 习题3.6 一元多项式的乘法与加法运算
  19. 一小时教你轻松学会使用Java 整合 Easy Excel 操作 Excel 文件
  20. 大数据技术原理与应用(林子雨)-NoSQL数据库单元测验

热门文章

  1. 电脑进程,电脑进程详解,哪些进程可以关闭
  2. java汽车美容管理计算机毕业设计MyBatis+系统+LW文档+源码+调试部署
  3. 2022-2028中国小型核磁共振波谱仪(NMR)市场现状研究分析与发展前景预测报告
  4. CSR8670项目实战:BlueDongle 蓝牙音频测试dongle
  5. xd导出标注html,使用标记狮一键导出Adobe XD标注文件到本地如何选择[导出包支持范围]...
  6. 简述安卓三种近场通信技术特点和场景应用
  7. Arduino用esp8266WiFi模块连接到服务器
  8. C++输入cin,cin.get(),cin.getline()详细比较及例子
  9. 双色球 机选号码+自选号码
  10. 入行四年的普通程序员是怎样的工作与生活