日常工作中常常需要重复填写某些表单,如果人工完成,费时费力,而且网络延迟令人十分崩溃。如果能够用程序实现自动填表,效率可以提高一倍以上,并且能够移植到多台计算机,进一步提高工作效率。webdriver是python的selenium库中的一个自动化测试工具,它能完全模拟浏览器的操作,无需处理复杂的request、post,对爬虫初学者十分友好。

一、环境配置

python3.6+selenium库+xlrd库+xlwt库

其中xlrd和xlwt库用于读写excel表中的数据。

还要下载一个浏览器的driver文件用于打开浏览器,注意要选择与计算机系统相符合的版本(max/windows64位/windows32位)

ChromeDriver:http://npm.taobao.org/mirrors/chromedriver/

IEDriver:http://selenium-release.storage.googleapis.com/index.html

将下载下来的driver.exe放到浏览器根目录和python的根目录

二、打开网页

以IE浏览器为例,以下两行代码就可以实现打开一个IE浏览器并且访问我们需要填表的网站

driver= webdriver.Ie()
driver.get('http://xxxx.com/')

如果网站需要登陆(需要填表的一般是公司内部网站),再写一个login函数,将driver作为参数调用

driver = login(driver)

注意一定要将driver传回,这样driver才能继续接受程序的指令

三、元素定位

webdriver的工作原理是找到网页中某一个元素,可以对其进行填入数据或点击等操作。
我主要用到的元素定位方式有

driver.find_element_by_id('someid')#通过元素的id定位
driver.find_element_by_css_selector("input[value='确定'")#查找一个input元素,它的value属性值为'确定'
driver.find_element_by_xpath("//span[contains(@style,'COLOR: red')]/span[1]")#查找一个style属性值为'COLOR:red'的span元素的第一个span子元素

(1)通过id定位

如果我们想在网页表单的某一个位置填某项值或者点击某个按钮,我们首先要用开发者工具查看这个元素的源代码,然后首先观察它有没有id,如果有id,直接用id定位该元素。然后,用

driver.find_element_by_id('someid').click()#点击元素
driver.find_element_by_id('someid').send_keys('somekeys')#填入'somekeys'
driver.find_element_by_id('someid').clear()#清空输入框中已有的值

实现我们想要做的操作。

(2)通过ccs selector定位

如果我们想要操作的元素没有ID,那么我们就要找到它跟网页其他元素不同的特征,ccs selector是一种十分灵活的定位方式,其中用value定位是一个不错的选择。以

driver.find_element_by_css_selector("input[value='确定'")

为例,双引号中的input可以换成任何网页元素(div、span、input、a等),中括号中是该元素的某一个属性(style、id、value、class等),等号后面是该属性的值。

注意,如果网页中有多个元素同时满足ccs selector的条件,如有多个value=“确定” 的input,那么find_element_by_css_selector只会定位到在html源代码中最靠前的一个,而find_elements_by_css_selector会找到源代码中所有满足条件的元素,并以列表的形式返回这些找到的元素。例如,网页中弹出很多个提示框,我们要一一去点确定,可以这样操作

list=driver.find_elements_by_css_selector("input[value=' 确定 ']")
for l in list:l.click()

但是,如果这些提示框是重叠出现的,而最上层的提示框实际上在源码中更靠后的位置,那么列表中第一个“确定”元素就会被叠在上面的提示框遮挡,无法点击,这个时候倒序一下数组就可以了,从最后一个“确定”元素开始点击

 query=driver.find_elements_by_css_selector("input[value=' 确定 ']")for q in query[::-1]:q.click()

(3)通过xpath定位

xpath定位比较复杂但是非常全面,当这个元素的class、style属性和其他元素一样,实在没什么特点可以一步定位的时候,我们就可以用xpath,先找到我们想要的元素的父子兄弟元素,再定位到我们想要的元素。例如

   driver.find_element_by_xpath('//*[@class="submit clear"]/input[1]').click()text =driver.find_element_by_xpath("//input[@value=' 确定 ']/../preceding-sibling::div[1]").textdriver.find_elements_by_xpath("//span[contains(@style,'COLOR: red')]/span[1]")'''
学习中遇到问题没人解答?小编创建了一个Python学习交流QQ群991032883
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''

引号中的//表示相对定位,表示从源代码中任何地方开始寻找。

//后可以跟任何元素,*代表任意元素,即定位符合属性筛选任何元素。

中括号内是属性的筛选条件,@后可以加任意属性。contains(@style,‘COLOR: red’)表示的筛选条件是:style属性中包含”COLOR:red“。这里为什么不直接用@style='COLOR: red’的原因是,可能在我们审查源代码的时候这个元素的style属性只有’COLOR: red’这一条,但是动态界面的style属性经常变化,程序运行时直接用等于是定位不到这个元素的。

我们通常需要靠先找到某个有id的元素,再通过层级关系定位到我们真正想要定位的元素

/… 可以定位这个元素的父亲元素

/ 可以定位这个元素的子元素

/preceding-sibling:: 可以定位这个元素的哥哥元素

/following-sibling:: 可以定位这个元素的弟弟元素

如/input[1]表示子元素中第一个input、/…/preceding-sibling::div[1]表示父元素的哥哥元素中的第一个div

(4)通过当前节点定位

有时候我们会遇到需要判断一下元素当前的状态(是否被选择)再决定接下来的操作的情况,这时就需要用一个变量来保存当前节点

   LTE=driver.find_element_by_xpath("//input[@id='LTE']/../span[1]"

然后再用get_attribute获得当前节点元素的属性,在这个例子里,如果元素为蓝色,就不需要点击。代码实现为:

'''
if LTE.get_attribute("style")=="COLOR: blue":pass
else:LET.click()

需要筛选出特定文本的情况:

red=driver.find_elements_by_xpath("//span[contains(@style,'COLOR: red')]/span[1]")#找出所有红色的文本
for r in red:if '低消' in r.text:#如果文本信息中包含‘低消’r.find_element_by_xpath("./../preceding-sibling::input[1]").click()#注意从当前节点定位的时候要以‘./’开头break

如果寻找的元素需要滚动界面才能看到,这个时候可以用js聚焦此元素,页面便会滚动到该元素的位置

target=driver.find_element_by_css_selector("input[value=' 确定 ']")
driver.execute_script("arguments[0].scrollIntoView();", target)
target.click()

四、不确定情况处理

(1)有可能出现的弹窗

在填表过程中,有些地方有可能出现一个弹框也有可能不出现,这个时候,无论这个弹窗是什么,用try…except语句处理就可以解决

js触发的弹窗:

try:driver.find_element_by_css_selector("input[value=' 确定 ']").click()
except Exception as e:pass

网页alert弹窗:

try:driver.switch_to.alert.dismiss()
except Exception:pass

dismiss()对应的是alert弹窗的”取消“项,accept()对应的是”确定“项,driver.switch_to.alert.text 可以获得弹窗的文本内容。

(2)数量不定的弹窗

对上文提到的多个提示框情况,除了用 query=driver.find_elements_by_css_selector(“input[value=’ 确定 ']”) 一次性找到所有元素再顺序或倒序点击之外,还可以用一个while循环解决

'''
while(1):try:driver.find_element_by_css_selector("input[value=' 确定 ']").click()except Exception as e:break

(3)网络延迟

有些网页在点击查询信息之后需要加载一段时间,加载中的页面是找不到我们接下来想找的元素的,因此程序就会报错,此时有两种解决方法。

一种是固定等待一段时间,等待网页加载完毕,这种方法的缺点是很难找到等待的最佳时间,太短的话页面还没加载完,太长就影响效率

time.sleep(2)

另一种是用一个while循环一直寻找下一个我们要找的元素

while(1):try:driver.find_element_by_id('continueTrade').click()breakexcept Exception:pass

这种方法的前提是下一个要找的元素必定会出现

五、frame处理

总结起来就是:frameset不用切,frame层层切。最好一系列填表操作完后都用 driver.switch_to.default_content() 回到原文档,这样不容易混乱

这里再补充一点frame没有id时的切入方法

frame= self.driver.find_element_by_xpath("/html/body/div[12]/iframe")#先定位frame位置,用一个变量储存这个节点
self.driver.switch_to_frame(frame)#再切入这个节点

六、excel数据读写

excel数据读写十分简单,看代码就好了:

def read(file):data = xlrd.open_workbook(file)#打开excel文件table = data.sheets()[0]#读取第一个sheet的数据phones = table.col_values(0)#以列表形式存储第一列数据peoples = table.col_values(1)#以列表形式存储第二列数据return phones,peoplesdef write(result):file=xlwt.Workbook()#创建一个excel文件table = file.add_sheet('sheet1')#添加一个sheetfor i in range(len(result)):#写入数据table.write(i,0,result[i][0])table.write(i,1,result[i][1])table.write(i,2,result[i][2])file.save('result.xls')

结语:希望技术能让人们从无意义的重复劳动中解脱:D

结尾给大家推荐一个非常好的学习教程,希望对你学习Python有帮助!

Python基础入门教程推荐:更多Python视频教程-关注B站:吴哈哈Sx1

Python爬虫案例教程推荐:更多Python视频教程-关注B站:吴哈哈Sx1

Python学习,用python-webdriver实现自动填表相关推荐

  1. Python 学习 02 —— Python如何爬取数据

    文章目录 系列文章 二.Python 爬 虫 1.任务介绍 2.简介 3.基本流程 3.1.准备工作 3.1.1.分析页面 3.1.2.编码规范 3.1.3.导入模块 3.1.4.程序流程 3.2.获 ...

  2. python爬虫原理-python学习之python爬虫原理

    原标题:python学习之python爬虫原理 今天我们要向大家详细解说python爬虫原理,什么是python爬虫,python爬虫工作的基本流程是什么等内容,希望对这正在进行python爬虫学习的 ...

  3. 深圳Python学习:Python几大问,你想知道的答案都在这里!-千锋

    深圳Python学习:Python几大问,你想知道的答案都在这里!-千锋 人们为什么使用Python? 之所以选择Python的主要因素有以下几个方面: 软件质量:在很大程度上,Python更注重可读 ...

  4. 视频教程-爬虫微课5小时 Python学习路线-Python

    爬虫微课5小时 Python学习路线 十多年的Java和大数据开发和培训,精通Hadoop.Spark和Android开发,对于数据分析和挖掘有比较深的研究.曾在公司独立开发O2O项目e小时.网店项目 ...

  5. 菜菜的Python学习日记 | Python类实验代码分享

    系列索引:菜菜的Python学习日记 | Python从入门到入土详解 Python类实验代码分享 编写程序,实现以下功能. (1)创建员工类Employee,属性有姓名name.能力值ability ...

  6. Python学习之Python软件安装教程

    Python学习之Python软件安装教程 Python学习之Python软件安装教程

  7. python源码学习_【Python学习】Python源码阅读(一)

    最近想读读Python源码,任何东西学习方法基本都是一样的,先从总体框架进行了解,再从自己侧重的方面逐步深入. 1. Python总体架构 左边是Python提供的大量的模块.库以及用户自定义的模块. ...

  8. python学习: 优秀Python学习资源收集汇总--转

    Python是一种面向对象.直译式计算机程序设计语言.它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用縮进来定义语句块.与Scheme.Ruby.Perl ...

  9. python学习手册-Python学习手册(第4版) 中文版.pdf

    您所在位置:网站首页 > 海量文档 &nbsp>&nbsp计算机&nbsp>&nbspPython Python学习手册(第4版) 中文版.pdf11 ...

最新文章

  1. WINDOWS和LINUX下带时间的PING包监控脚本
  2. 病毒入侵计算机的危害,那些年电脑中过的病毒,中病毒的危害又有哪些
  3. 2017广西邀请赛重现赛
  4. nb信号和4g信号_手机信号很强但是4G网络却很卡?学会这三招,立马恢复网速
  5. 一些试题:C++面试题.万能Key
  6. 208. 实现 Trie (前缀树)
  7. c语言课设报告时钟vc环境,C语言课程设计报告模拟时钟转动程序.doc
  8. java爬取网页并保存_第九讲:Python爬取网页图片并保存到本地
  9. IntelliJ IDEA上手这一篇就够了,从入门到上瘾
  10. TempTable临时表
  11. oracle 空间数据库说明
  12. python编程入门 适合于零基础朋友-零基础能学好python吗?教女朋友学python是送命题吗?...
  13. 啦啦外卖独立版42.0至尊版全开源含vue代码修复app没声音
  14. ukey其他错误_关于税务UKey使用常见问题解答
  15. html div自动换行代码,css自动换行_css
  16. java解析project mpp文件,如何在Java中创建.mpp文件?
  17. C. Dominant Character (思维 暴力
  18. 继电器驱动设计方案及问题分析
  19. 2018年中考计算机考试成绩,2018年中考分数线
  20. 最常见的8种网络安全攻击类型!

热门文章

  1. HttpClient和HtmlUnit的比较总结以及使用技巧(一)
  2. 性能测试能力提升最终篇-全链路压测
  3. 认识IBinder和Binder
  4. 网络学习 2g 3g 4g 技术对比 带宽理解 三大运营商手机网络模式 (制式)
  5. 【机器人学习】 四足机器人(单腿三自由度)正运动学与轨迹规划仿真(solidwork三维模型+matlab代码)
  6. 好用的php博客系统,个人博客系统推荐 PHP开源好用的BLOG程序大全
  7. linux创建用户,添加及修改shell
  8. 使用bins对数据进行分段并计算每个分段的数据量
  9. Scanner的基本用法
  10. Handlebars的使用方法文档整理(Handlebars.js)