时间:2021-05-22
实现网页的键盘输入操作
from selenium.webdriver.common.keys import Keys 动态网页有时需要将鼠标悬停在某个元素上,相应的列表选项才能显示出来。 而爬虫在工作的时候也需要相应的操作,才能获得列表项。 driver.find_element_by_class_name(...).send_keys(需要输入的字串) #find_element_by_class_name可以是find_element_by_link_text、find_element_by_id等其他方式 #send_keys一些特殊字符串,可以通过help(Keys)显示出来,如实现按回车操作需要使用Keys.ENTER实现网页上的鼠标的动作
driver.find_element_by_link_text('更多').click()#需要指示到/a链接的位置
#同样find_element_by_link_text可以是find_element_by_id等类似的其他方式
使用ActionChains可以实现鼠标的更多操作
from selenium.webdriver.common.action_chains import *ActionChains中的操作:
click() -- 单击、click_and_hold()-- 按下鼠标左键在一个元素上、context_click() --单击、double_click()--双击、drag_and_drop()--拖动、key_down()、key_up()、move_by_offset()、move_to_elment()、move_to_elment_with_offset()
动态网页鼠标操作及遇到的问题
动态网页有时需要将鼠标悬停在某个元素上,相应的列表选项才能显示出来。而爬虫在工作的时候也需要相应的操作,才能获得列表项。
#首先需要将鼠标停留到相应的元素chain = ActionChains(driver)moveelment = driver.find_element_by_xpath("...")chain.move_to_element(moveelment).perform()driver.find_element_by_xpath("//div[@class='search-condition c5 drop-down']/a/div").click()#而后进行选择列表项driver.find_element_by_xpath("//ul[@id='category_list']/li[1]/a").click()driver.find_element_by_xpath("//ul[@id='category_list']/li[2]/a").click()而当想要进行多列操作时出现了问题:driver.find_element_by_xpath("//ul[@id='category_list']/li[2]/a").click()一直无法成功仔细debug发现:在人工浏览查看相应列表时,全屏情况下列表显示是3列,而当需要聚焦特殊网页时,通过解析current_url进行比较即可,是否存在更好的方法。如果窗口很小就只能显示第一列的值。所以尝试将爬虫后台浏览器窗口设置成最大化,程序正常工作,如下:
#... ... driver.find_element_by_xpath("//ul[@id='category_list']/li[1]/a").click() driver.maximize_window() time.sleep(1) driver.find_element_by_xpath("//ul[@id='category_list']/li[2]/a").click()关于窗口的页面切换方式
经常在网页操作时,会弹出新的页面,而爬虫需要程序进行窗口间的切换。
#切换网页,以获取新弹出的网页窗口 for handle in driver.window_handles: driver.switch_to_window(handle) print('current url:%s'%driver.current_url)当需要聚焦特殊网页时,通过解析current_url进行比较即可,是否存在更好的方法。
以上这篇Python爬虫信息输入及页面的切换方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
电脑输入法切换不了的原因及解决方法电脑输入法切换不了的原因及解决方法电脑输入法切换不了的原因及解决方法电脑输入法切换不了的原因及解决方法电脑输入法切换不了的原因
目前市面上流行的爬虫以python居多,简单了解之后,觉得简单的一些页面的爬虫,主要就是去解析目标页面(html)。那么就在想,java有没有用户方便解析htm
Python爬虫之超链接url中含有中文出错及解决办法python3.5爬虫错误:UnicodeEncodeError:'ascii'codeccan'tenc
[目录]扯淡吹逼之开发前奏Django开发环境搭建及配置Bootstrap前端页面开发Djangoapp开发Django站点管理Python简易爬虫开发Ngin
一、什么是爬虫爬虫:一段自动抓取互联网信息的程序,从互联网上抓取对于我们有价值的信息。二、Python爬虫架构Python爬虫架构主要由五个部分组成,分别是调度