首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Python无头爬虫Selenium系列(01):像手工一样操作浏览器

搜索并采集结果的标题 需求如下: 打开百度搜索主页 在输入框输入搜索内容(比如"爬虫") 点击"百度一下"按钮,进行搜索 把结果页面中的第一页的各个结果的主标题抓取下来 Selenium 的麻烦之处 本系列始终围绕一点开展...:"用代码操作浏览器",下面看看整个流程: Python 代码通过 selenium 库,控制"浏览器驱动"程序(一个 exe 文件) "浏览器驱动"程序则发送指令操控"浏览器" 但是,市面上存在各种浏览器...他有如下优点: selenium 库已经开发很久,相对来说比较稳定 selenium 在各个语言的库都是有 google 开发维护,因此不会出有些问题只在 Python 版本出现 selenium 相比...首先,使用 pip 安装 selenium !pip install selenium 你可以在 jupyter notebook 的 cell 中执行 "!...有2种常见的方式,css 选择器 或者 xpath selenium 文档中强烈推荐你使用 css 选择器 我们选用 css 选择器,因此,在右区的 input 标签上,按鼠标右键,选 "copy" ,

2.4K20

Selenium自动化|爬取公众号全部文章,就是这么简单

Selenium介绍 Selenium是一个用于web应用程序自动化测试的工具,直接运行在浏览器当中,可以通过代码控制与页面上元素进行交互,并获取对应的信息。...Python”,并且根据“搜文章”按钮的xpath获取该位置并点击,这里就用到了显式等待。...跳转了下一页后可以发现不是所有的文章都由“早起Python”公众号推送。 ? 另外只能获取前10页100条的结果,中间需要微信扫码登录 ?...因此从这里开始,代码的执行逻辑为: 先遍历前10页100个文章的公众号名字,如果不是“早起Python”则跳过,是则获取对应的标题名字、发布日期和链接 第10页遍历完成后自动点击登录,此时人为扫码确定登录...对,就是数据存储,在爬下来数据之后和之前一样利用openpyxl存储到excel中即可 ?

2.5K21
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    RobotFramework工具试用

    可配制多个,使用“,”分隔 · 脚本运行记录显示区:执行过程中的记录信息 · 系统运行记录显示区:扫行过程中的相关系统记录信息 3.2 写简单用例 Ø 创建测试项目 打开ride,在菜单栏File中,选择...Ø 导入库 在实际项目中,我们需要运用 RF 框架编写基于 web 的测试用例,我们需要 Selenium 的库支持。所以,我们在使用的过程中需要加载 selenium2library 库。...在“测试套件”的 Edit 标签页,点击“Library”按钮,弹出输入框,Name 输入:Selenium2Library ,点击 OK 完成。 如果导入的库显示为红色,表示导入的库不存在。...”.在弹出框中输入Name、Arguments,选择“OK” 选择新增的Keyword,在Edit 标签页,使用公共类库中的源生AW去封装我们业务需要的AW。...Ø 测试用例层 通过公共类库和其他各层的封装,去输出简洁易懂的用例脚本; 在“测试套件”的 Edit 标签页,点击“Resource”按钮,选择对应的内容层文件 ,点击 OK 完成。

    2.7K00

    【实测】playwright 学习笔记 - 02

    当我点击了一下这个按钮之后,神奇的一幕发生了,这个生成的代码编辑框中居然自动添加了这一句代码: 然后我试着又点击了一下面试题进入按钮,不出意外,这句代码又自动生成了: 然后我再随便点击了一道面试题...后续如果有什么一开始要进行设置的代码可以尝试放在这个with代码块中,比如并发去调用run函数启动多个浏览器并发测试。...之后我们要测试一下,如果多个声明的话,那是启动多个浏览器窗口,还是在一个浏览器下的多个标签页。 7行是page变量声明,依靠context的创建,看英文名字起来是新建了一个页面。...并且下面的代码都是page.xxxxx ,看起来很像selenium的driver,但此刻我有一些疑惑,driver是可以控制多个页面多个标签页的,而这个page听起来就好像只能在当前标签页进行操作。...我们实际工作中要根据需要来选择关闭到何种程度,在pytest或者unitest中,也要把这几个关闭放在恰当的位置来让多个用例进行正常执行。

    37220

    Python无头爬虫Selenium系列(01):像手工一样操作浏览器

    搜索并采集结果的标题 需求如下: 打开百度搜索主页 在输入框输入搜索内容(比如"爬虫") 点击"百度一下"按钮,进行搜索 把结果页面中的第一页的各个结果的主标题抓取下来 Selenium 的麻烦之处 本系列始终围绕一点开展...:"用代码操作浏览器",下面看看整个流程: Python 代码通过 selenium 库,控制"浏览器驱动"程序(一个 exe 文件) "浏览器驱动"程序则发送指令操控"浏览器" 但是,市面上存在各种浏览器...他有如下优点: selenium 库已经开发很久,相对来说比较稳定 selenium 在各个语言的库都是有 google 开发维护,因此不会出有些问题只在 Python 版本出现 selenium 相比...首先,使用 pip 安装 selenium !pip install selenium 你可以在 jupyter notebook 的 cell 中执行 "!...有2种常见的方式,css 选择器 或者 xpath selenium 文档中强烈推荐你使用 css 选择器 我们选用 css 选择器,因此,在右区的 input 标签上,按鼠标右键,选 "copy" ,

    3.8K30

    爬虫进阶(二)

    数量果真有点多,每一页有四十多家,也就是用“用Python写网络爬虫”这个词做搜索词出现了四百多个结果,如果人为去筛选,会有多累。既然学了爬虫,就要用到实际生活中,所以用爬虫来爬取这四百多条数据。...老规矩,我们先用预演一遍如果人工去实现这个过程会怎么做: 打开淘宝——找到输入框并输入《用Python写网络爬虫》——点击搜索——出现商品页——把第一页中的所有商品信息记录下来——然后进行翻页到下一页—...02|selenium介绍: 1、selenium是什么 Selenium是一个用于Web应用程序测试的工具。Selenium测试直接运行在浏览器中,就像真正的用户在操作一样。...在本篇内容中,我们将利用selenium去进行打开淘宝页面、输入关键词、点击搜索、翻页等操作,下图为一些API。...打开淘宝——找到输入框并输入《用Python写网络爬虫》——点击搜索——出现商品页——把第一页中的所有商品信息记录下来——然后进行翻页到下一页——重复记录信息的动作——直至最后。

    1.4K80

    如何使用Selenium Python爬取多个分页的动态表格并进行数据整合和分析

    本文将介绍如何使用Selenium Python这一强大的自动化测试工具来爬取多个分页的动态表格,并进行数据整合和分析。...正文 Selenium Python简介 Selenium是一个开源的自动化测试框架,它可以模拟用户在浏览器中的操作,如点击、输入、滚动等,从而实现对网页的自动化测试或爬取。...我们需要用Selenium Python提供的各种操作方法,如click、send_keys等,来模拟用户在表格中翻页,并用BeautifulSoup等库来解析表格数据,并存储到列表或字典中。...有些网站可能使用数字按钮来表示分页,有些网站可能使用上一页和下一页按钮来表示分页,有些网站可能使用省略号或更多按钮来表示分页,我们需要根据不同情况来选择合适的翻页方法。 需要处理异常情况和错误处理。...在爬取过程中,可能会遇到各种异常情况和错误,如网络中断、页面跳转、元素丢失等,我们需要用Selenium Python提供的异常处理方法来捕获和处理这些异常,并设置重试机制和日志记录。

    1.7K40

    Selenium + C# 实现模拟百度贴吧签到 1

    它的下载页面里有很多东西,我们只需要Selenium Client,它支持了很多语言(C#、JAVA、Ruby、Python、NodeJS),按自己所学语言下载即可。...其实最终数据都会完整的显示在界面上,既然数据能够显示出来,使用Selenium操控WebDriver进行模拟浏览器行为(点击,切换,移动)等等事件,等待数据显示,然后使用选择器(Id,Class,XPath...下面使用Selenium进行一个简单的百度贴吧一键签到功能编码 项目创建,环境配置 打开Vs,新建控制台项目,使用Nuget获取最新Selenium的C#库,然后根据自己机型安装的浏览器选择WebDirver...chrome.webdriver.png 下载完成后在项目根目录的packages文件夹中找到对应内容 根据系统类型,系统是32还是64自行选择 ?...编码的逻辑就是如下 1、打开网页 2、找到下一页按钮 3、模拟点击 4、数据获取 这样的方式就和我们使用浏览器操作习惯一置,逻辑也更加清楚。

    1.1K40

    Selenium自动化测试技巧

    跨浏览器测试中的Selenium 顾名思义,跨浏览器测试是一种用于在不同的Web浏览器和设备上测试Web应用程序以确保其在每个设备和浏览器上都能无缝运行的方法。...Selenium帮助在Safari,Google Chrome,Mozilla Firefox和IE中自动化测试案例。Selenium也可以同时在不同浏览器上的同一台计算机上执行测试用例。...参考文章: 如何在跨浏览器测试中提高效率 让我们看一下Selenium的最佳实践,以在自动化测试过程中充分利用。...Selenium还允许客户从其框架中受益。客户可以利用专有的测试加速器并启动测试自动化。这将减少自动化周期时间。有很多个函数库,可让客户端启动自动化过程。...在3个没有数据的表中,XPath识别第二个表的速度最慢,并且可能不会返回正确的表。因此,最后选择了XPath,它们很脆弱。CSS始终与名称和ID结合在一起。

    1.6K20

    Python 自动化指南(繁琐工作自动化)第二版:十二、网络爬取

    如果我能简单地在命令行中输入一个搜索词,让我的电脑自动打开一个浏览器,在新的标签页中显示所有热门搜索结果,那就太好了。...然后这个帖子还会有一个“上一页”按钮,以此类推,创建一个从最近的页面到站点上第一个帖子的轨迹。如果你想要一份网站内容的拷贝,以便在不在线时阅读,你可以手动浏览每一页并保存每一页。...Prev 按钮有一个值为prev的rel HTML 属性。 第一个漫画的“上一页”按钮链接到xkcd.com网址,表示没有更多的上一页。 使您的代码看起来像下面这样: #!...(例如,您可能会运行pip install --user -U selenium==3.14.1。) 在页面上查找元素 对象有很多方法来寻找页面上的元素。...这个方法可以用来跟踪一个链接,在一个单选按钮上进行选择,单击一个提交按钮,或者触发鼠标单击元素时可能发生的任何事情。

    8.7K70

    用 Python 爬取 QQ 空间说说和相册

    QQ 空间在 2005 年被腾讯开发,已经经历了 15 个年头,在还没有微信的年代,看网友发表的心情、心事、照片大多都在 QQ 空间的里。...它承载了80、90 后的大量青春,下面我们一起用 selenium 模块导出说说和相册回忆青春吧 安装 selenium selenium 是一个在浏览器中运行,以模拟用户操作浏览器的方式获取网页源码,...使用 pip 安装 selenium 模块 pip install selenium 查看 chrome 浏览器版本并下载 对应的 chrome 浏览器驱动 在 http://npm.taobao.org.../mirrors/chromedriver 网址中找到相同版本的 chrome 驱动,并放在 python 程序运行的同一个文件夹中 登陆 按 F12 检擦网页源代码,找到登录和密码的文本框,如下图所示...模块模拟鼠标一步步点击页面,先点击上方的相册按钮,进去就是多个相册的列表,下图是单个相册的超链接 在单个相册中点击照片,界面如下图 def get_photo(driver):

    3.5K30

    Selenium Python使用技巧(三)

    书接上文和上上文: Selenium Python使用技巧(一) Selenium Python使用技巧(二) 处理不同情况的等待 在Selenium自动化测试中网页可能需要花费一些时间来加载,或者希望在触发测试代码之前可以看到页面上的特定...driver.quit() 网页中的滚动操作 在使用Selenium执行测试自动化时,您可能需要在页面上执行上滚/下滚操作的要求。...使用Selenium放大和缩小 为了在进行Selenium自动化测试时放大或缩小,应使用transformCSS属性(适用于相应的浏览器),该属性可让您在页面上执行放大,缩小,旋转,倾斜等操作。...在下面的示例中,我们在页面中计算按钮create_programmatic_menu(ID = createDestoryButton)的大小。...支持以验证自动跨浏览器与Selenium自动化测试的兼容性,则需要更改被测浏览器的配置文件设置(在本例中为Firefox),并将更改应用于配置文件。

    1.7K30

    Selenium WebDriver找不到元素的三种情况

    其实呢是在操作的过程中页面发生了变化,刷新了,虽然表面上看起来两个元素长得一模一样,事实上是每一个元素都有自己的一个ID号。 用代码(Python)来证明!...比如:一排分页按钮,你点击下一页跳转到了第二页,想要还用原来的元素操作到下一页,那也是不可能的了。...情况二:iframe原因定位不到元素需要切换Iframe 【参考此文】 这种情况一般发生在有内嵌的iframe的情况下,需要切换一下iframe 另外注意的是有的页面会有多个iframe,找不到元素同样是没有切换...提供的超时等待,implicitly_wait()方法 Python:driver.implicitly_wait(20) 添加智能等待时间,在设置的时间内,默认每隔一段时间检测一次当前页面元素是否存在...可参考博文:Selenium使用之——添加等待时间的三种方式

    5.3K50

    如何使用Selenium Python爬取动态表格中的多语言和编码格式

    本文将介绍如何使用Selenium Python爬取一个动态表格中的多语言和编码格式的数据,并将其保存为CSV文件。特点Selenium可以处理JavaScript渲染的网页,而不需要额外的库或工具。...Selenium可以使用XPath、CSS选择器等定位元素,以提取所需的数据。Selenium可以处理多语言和编码格式的数据,如中文、日文、UTF-8等,只需要设置相应的参数。...定位表格元素,并获取表头和表体的数据。循环点击分页按钮,并获取每一页的数据。切换语言选项,并重复步骤4和5。切换编码格式选项,并重复步骤4和5。将所有数据保存为CSV文件,并关闭浏览器。...第46行,定义一个列表,用于存储所有的数据,该列表将包含多语言和编码格式的数据。第48行到第53行,循环点击分页按钮,并获取每一页的数据,这是为了爬取表格中所有的数据。...结语本文介绍了如何使用Selenium Python爬取一个动态表格中的多语言和编码格式的数据,并将其保存为CSV文件。

    29630

    Python无头爬虫Selenium系列(02):等待机制

    否则很容易"从入门到入狱" 本系列大部分案例同时采用 selenium 与 pyppeteer 库讲解,并且有 Python 和 C# 2门语言的实现文章,详细请到公众号目录中找到。...Selenium 的等待机制同样如此,而上述机制中唯一可以变化的就是"查找规则",这体现为 wait.until 的第一个参数接受一个"可调用对象" ---- 终于得到你 这次案例的网页是我简单创建的...,输入 "localhost:8081/web_sp" 出现页面 点击页面上的按钮,下方出现新文本 ---- 现在用代码对这个页面采集,看看网页内容结构。...class 属性为 "content" 的标签 大概 10 秒后,代码执行结束,报了一个错误: 行5 中,wait.until 中的 lambda,大概被执行了 20 次(0.5秒一次,执行了10...秒) ---- 我们再次执行代码,这次我们在页面出来之后10秒内,点击页面上的按钮: 这次代码执行完毕,并执行到行6,得到我们要的结果 ---- 等你 n 次 了解这个机制,我们可以很灵活定制属于自己的查找条件

    1.3K20

    利用 Python 爬取 QQ 空间说说和相册

    QQ 空间在 2005 年被腾讯开发,已经经历了 15 个年头,在还没有微信的年代,看网友发表的心情、心事、照片大多都在 QQ 空间的里。...安装 selenium selenium 是一个在浏览器中运行,以模拟用户操作浏览器的方式获取网页源码,使用 pip 安装 selenium 模块 pip install selenium 查看 chrome...在 http://npm.taobao.org/mirrors/chromedriver 网址中找到相同版本的 chrome 驱动,并放在 python 程序运行的同一个文件夹中 登陆 按 F12 检擦网页源代码...,显示一页的说说是滚动加载的,必须要多次下拉滚动条后才能获取到该页所有的说说,然后用 BeautifulSoup 模块构建对象解析页面,下图是放说说的 iframe ?...模块模拟鼠标一步步点击页面,先点击上方的相册按钮,进去就是多个相册的列表,下图是单个相册的超链接 ?

    3.2K10

    Python爬取全市场基金持仓,扒一扒基金经理们的调仓选股思路

    虽然距离基金二季报公布的DDL已过去近1个月,但我们还是赶(bu)个(shi)晚(tuo)集(yan),分享一下基于python爬取天天基金网基金持仓数据的方法,最新及历史持仓数据均可爬。...可进一步定位基金名称、成立日、类型、基金经理、管理人字段信息 3)基金持仓:CSS选择器语法下’#cctable > div > div’可定位持仓明细表格 4)年份选择按钮:XPath语法下’//*[...@id='pagebar']/div/label[@value={年份}]’ 注:CSS选择器、XPath用于选取并控制html、xml页面中的元素/节点。...当我们想爬取历史年份持仓时,历史数据在初始html页面上是看不到的,需要点击年份选择按钮后才可加载。这种情况下,requests爬取困难,就需要召唤selenium了。...}]").click() 3.爬取全市场基金列表 4.爬取指定基金近N年持仓 注意有些基金是不持有股票的,但仍会有详情页,在详情页取表时会抛出异常,要对此情况进行处理。

    1.6K21

    .NET(C#)无头爬虫Selenium系列(02):等待机制

    ---- FindElements 无法等待的原因 这次项目自带 web 服务,启动调试会先启动 web 服务,在浏览器中输入本机 ip 即可浏览本文案例网页,操作看视频: vs 启动调试后,打开浏览器页...,输入 "localhost:8081" 出现页面 点击页面上的按钮,下方出现新文本 ---- 用"开发者工具",查看元素的标签: 可以看到,新增的内容都是由一个 div 标签包围,他们的共同特征是...这里的根本问题在于,wd.FindElements 在页面上找不到任何符合条件的元素,但是 wait 对象却没有重复查找 这是因为,wait 对象中的逻辑是,委托中的调用返回 null 或有异常,才被识别为继续等待...我们点击页面上的按钮,代码就会继续执行,并显示出结果 ---- 打造更加简洁的语义 如果每次使用 Selenium 都要写上这些代码,那真的太麻烦了。...不过在 .net 中可以很容易扩展自己的语义。

    2.5K40

    python3 爬虫第二步Selenium 使用简单的方式抓取复杂的页面信息

    是个不错的选择。...在html中,大部分有特殊作用的元素会赋予一个id,搜索时需要填写的是百度搜索关键字的文本框,将鼠标移动到文本框,对准文本框点击鼠标右键,点击检查可以查看元素。 ?...在源代码中右键,选择Copy之后点击Copy XPath,这时我们就把当前这个元素的XPath获取了。 ?...以上省略了浏览器自动打开并搜索内容的过程,直接查看了结果。 那么我们每一页都获取第一个结果,这时只需要自动点击下一页后获取即可。 首先得到下一页按钮的元素对象: ?...XPath 中变化的值为11-21-31…,设置一个变量为1,每次加10即可,所以在循环中,第一句为: start+=10 由于XPath的值其它字符串没变化,所以整一条XPath语句可以写为: xpath_val

    2.2K20

    python 爬虫之selenium可视化爬虫

    前文回顾 一文带你了解Python爬虫(一)——基本原理介绍 一文带你了解Python爬虫(二)——四种常见基础爬虫方法介绍 之所以把selenium爬虫称之为可视化爬虫 主要是相较于前面所提到的几种网页解析的爬虫方式...selenium可以模拟真实浏览器,自动化测试工具,支持多种浏览器, 爬虫中主要用来解决JavaScript渲染问题。...用python写爬虫的时候,主要用的是selenium的Webdriver, #安装selenium库 pip install selenium #安装对应浏览器驱动 # 我们可以通过下面的方式先看看Selenium.Webdriver...设置超时时间10秒,webDriverWait默认会500ms检测一下元素是否存在 selenium提供了一些内置的用于显示等待的方法, 位于expected_conditions类中,详细见下表...alert_is_present 判断页面上是否存在alert框 2.隐式等待 隐式等待是在尝试定位某个元素时,如果没能立刻发现,就等待固定时长 类似于socket超时,默认设置是0秒,即相当于最长等待时长

    2K61
    领券