python学习(二):selenium环境配置及jandan网爬虫修改

2024-01-17 21:10

本文主要是介绍python学习(二):selenium环境配置及jandan网爬虫修改,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

python学习二

  • 这篇是跟着梦想橡皮擦的爬虫课项目18爬取煎蛋网妹子图的时候对selenium的使用和安装走了一些弯路,写出来供大家参考
    • 1、橡皮擦的项目18中的问题
    • 2、selenium安装过程中的问题

这篇是跟着梦想橡皮擦的爬虫课项目18爬取煎蛋网妹子图的时候对selenium的使用和安装走了一些弯路,写出来供大家参考

1、橡皮擦的项目18中的问题

橡皮擦该项目的教程地址:https://cloud.tencent.com/developer/article/1388460
橡皮擦老师的教程省略了selenium的安装过程,简单补充一下。selenuim模块作为测试工具,用来模拟浏览器行为,可以通过获取浏览器上面的按钮对象完全模拟所有用户动作。一般我们都是使用Chrom和Firefox浏览器去模拟登录,selenium也提供了对应的模块,但是橡皮擦老师这次很反常地在代码里使用了PhantomJS加载浏览器。实操的时候发现版本限制已经不支持PhantomJS 了。
另外代码里面有一些小的问题可能影响运行,我稍微修改了一下,希望橡皮擦老师不要恼火,可执行的代码放到这里
https://github.com/daniuyan/learngit/tree/master/xxoo18
供参考

2、selenium安装过程中的问题

之前没有实操这个项目的原因就是安装selenium过程很蛋疼,这次想系统地学习一下这个模块,一定要脚踏实地地敲好代码。所以开始了selenium安装的踩坑之旅。
因为python3.5的版本较低,升级python到3.7之后pip3安装selenium,这个没什么说的
pip3 install selenium,自动安装的版本是selenium-3.14

Installing collected packages: selenium
Successfully installed selenium-3.141.0

安装之后先按照老师的PhantomJS加载,提示版本不支持,因为我的环境是Ubantu16.04-64bit,自带了火狐浏览器,所以就安装geckodriver,喜欢Chrom的朋友就自我探索一下吧。
第一件事自然就是下载geckodriver了,下载连接
https://github.com/mozilla/geckodriver/releases
这个链接地址不是太好下,必要的时候多换几个环境下载,当然也可以在CSDN找资源,虽然我很不喜欢有偿资源,但是想想别人找资料也很辛苦,就支持一下内容,我就不放免费链接了(各种版本的geck早就都有了,我也赚不了积分)。
仔细阅读,发现不同的浏览器版本有不同的geckodriver,机智的我当然要看一下
在这里插入图片描述机智的我又去查了一下虚拟机上的火狐版本65.0.1
肯定不能下载最新的,但是并不是每个版本都有对应的说明,机智的我又去找了一个大家用的最多的版本v0.20.0
下载,解压,安装,放到bin目录下,真是很顺利呢

liufeng@ubuntu:~$ tar -xvzf geckodriver-v0.23.0-linux64.tar.gz
geckodriver
liufeng@ubuntu:~$ sudo chmod +x geckodriver
[sudo] password for liufeng:
liufeng@ubuntu:~$ sudo mv geckodriver /usr/local/bin/

运行的时候悲剧了

    browser=webdriver.Firefox()File "/usr/local/lib/python3.7/site-packages/selenium/webdriver/firefox/webdriver.py", line 174, in __init__keep_alive=True)File "/usr/local/lib/python3.7/site-packages/selenium/webdriver/remote/webdriver.py", line 157, in __init__self.start_session(capabilities, browser_profile)File "/usr/local/lib/python3.7/site-packages/selenium/webdriver/remote/webdriver.py", line 252, in start_sessionresponse = self.execute(Command.NEW_SESSION, parameters)File "/usr/local/lib/python3.7/site-packages/selenium/webdriver/remote/webdriver.py", line 321, in executeself.error_handler.check_response(response)File "/usr/local/lib/python3.7/site-packages/selenium/webdriver/remote/errorhandler.py", line 242, in check_responseraise exception_class(message, screen, stacktrace)
selenium.common.exceptions.WebDriverException: Message: newSession

再去百度,发现有说selenium版本不对的,有说要降级python的。归根结底,就是版本不匹配,至于是哪个高了,哪个低了,我只是将geckodriver版本从20开始一个一个试过去,发现23这个版本可以正常运行。
后面要做的就是把老师的代码跑起来,美滋滋地等着收图了。
在这里插入图片描述这次练习最大的收获就是把selenium配置好了,以后学习这一个模块就更方便了。

这篇关于python学习(二):selenium环境配置及jandan网爬虫修改的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

IDEA中配置Tomcat全过程

《IDEA中配置Tomcat全过程》文章介绍了在IDEA中配置Tomcat的六步流程,包括添加服务器、配置部署选项、设置应用服务器及启动,并提及Maven依赖可能因约定大于配置导致问题,需检查依赖版本... 目录第一步第二步第三步第四步第五步第六步总结第一步选择这个方框第二步选择+号,找到Tomca

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

Win10安装Maven与环境变量配置过程

《Win10安装Maven与环境变量配置过程》本文介绍Maven的安装与配置方法,涵盖下载、环境变量设置、本地仓库及镜像配置,指导如何在IDEA中正确配置Maven,适用于Java及其他语言项目的构建... 目录Maven 是什么?一、下载二、安装三、配置环境四、验证测试五、配置本地仓库六、配置国内镜像地址

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放

python panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group

Python pandas库自学超详细教程

《Pythonpandas库自学超详细教程》文章介绍了Pandas库的基本功能、安装方法及核心操作,涵盖数据导入(CSV/Excel等)、数据结构(Series、DataFrame)、数据清洗、转换... 目录一、什么是Pandas库(1)、Pandas 应用(2)、Pandas 功能(3)、数据结构二、安

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

Python安装Pandas库的两种方法

《Python安装Pandas库的两种方法》本文介绍了三种安装PythonPandas库的方法,通过cmd命令行安装并解决版本冲突,手动下载whl文件安装,更换国内镜像源加速下载,最后建议用pipli... 目录方法一:cmd命令行执行pip install pandas方法二:找到pandas下载库,然后

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买