一、webdriver基本使用命令

from selenium import webdriver   # 导入webdriver模块

>>> chrome_obj = webdriver.Chrome()              # 打开Google浏览器
>>> chrome_obj.get("https://www.baidu.com") # 打开 网址 >>> chrome_obj.get(r"C:\desktop\text.html") # 打开本地 html页面 >>> chrome_obj.title # 获取打开网址 的名字
>>> chrome_obj.current_url # 获取打开网址的 url >>> chrome_obj.close() #关闭浏览器窗口

  

二、标签导航 

普通 定位标签

# 查找标签
>>> label = chrome_obj.find_element_by_id("kw")
>>> label = chrome_obj.find_element_by_name("wd")
>>> label = chrome_obj.find_element_by_class_name("s_ipt")
>>> label = chrome_obj.find_element_by_tag_name("imput") >>> label = chrome_obj.find_element_by_link_text("a标签中的内容 准确定位")
>>> label = chrome_obj.find_element_by_partial_link_text("a标签中的内容 模糊定位 ") >>> label = chrome_obj.find_element_by_xpath(“放入 copy 标签中的常css路径”)
>>> label = chrome_obj.find_element_by_css_selector(“input=[id='id_name'/name='name_name'/……/]")

  

标签导航  xpath  标签定位复杂的情况下 考虑使用xpath

XPath即为XML路径语言,它是一种用来确定XML标准通用标记语言的子集)文档中某部分位置的语言。XPath基于XML的树状结构,有不同类型的节点,包括元素节点,属性节点和文本节点,提供在数据结构树中找寻节点的能力。

# 绝对路径
>>> label = chrome_obj.find_element_by_xpath("html/boday/p/input") # 绝对路径 导航
>>> label = chrome_obj.find_element_by_xpath("html/boday/p/input[1]") # 绝对路径导航,多个input框,确定第一个input框 #相对路径
>>> label = chrome_obj.find_element_by_xpath("//input") # 相对路径导航 表示 整个文档当中的 input标签 默认为第一个 * 第一个“//” 表示 在整个文档中
>>> label = chrome_obj.find_element_by_xpath("//input[2]") # 指定页面中的第二个 input框 没有就报错 # 父节点下找子节点
>>> label = chrome_obj.find_element_by_xpath("//form//input") # // 父节点//子节点 * 返回子节点 input
>>> label = chrome_obj.find_element_by_xpath("//form//input[2]") # // 父节点//子节点 [2] * 指定 父节点下的 第二个 input子节点 # 通过子节点 定位父节点
>>> label = chrome_obj.find_element_by_xpath("//form//input/..") # 返回input的父节点 form 标签
>>> label = chrome_obj.find_element_by_xpath("//form//input/.") # 当前节点 # 通过属性查找节点
>>> label = chrome_obj.find_element_by_xpath("//input[@id]") # 相对路径导航 找到所有的 input标签 其中有 id属性的标签
>>> label = chrome_obj.find_element_by_xpath("//input[@id='1']") # 属性查找 在所有的input标签中 找到 具有 id=1 的input标签
>>> label = chrome_obj.find_element_by_xpath("//input[@name='xiahua']") # 标签统计 countains
>>> label = chrome_obj.find_element_by_xpath("//*[countains(input)=1]") # //* 表示 整个文档中 的所有标签,[count(input)=1] 表示 父标签下只有 一个input子标签 的 input标签
>>>label = chrome_obj.find_element_by_xpath("//*[countains(input)=2]") # //* 表示 整个文档中 的所有标签,[count(input)=1] 表示 父标签下有 两个input子标签 的 input标签 # local-name 模糊查找
>>> label = chrome_obj.find_element_by _xpath("//*[local-name()='input']") # 查找当前文档中 的所有input标签 默认返回第一个
>>> label = chrome_obj.find_element_by _xpath("//*input") # 查找当前文档中 的所有input标签 默认返回第一个 >>> label = chrome_obj.find_element_by _xpath("//*[local-name(),'i']") # 查找当前文档中 标签名字中 包含字母 i的标签,比如 input title
>>> label = chrome_obj.find_element_by _xpath("//*[local-name(),'i']") # 查找当前文档中 的所有input标签 默认返回第一个 >>> label = chrome_obj.find_element_by _xpath("//*[countains(local-name(),'i')] [last()]) # 查找当前文档中 所有包含 字母“i”的 标签 的子标签 的 最后一个元素 (有点懵逼)
>>> label = chrome_obj.find_element_by _xpath("//*[strint-length(local-name()=3)] [last()]) # 查找当前文档中 所有 标签字符个数为5的标签,并且制定返回 最后一个标签。 title input(5个str)

  

  

三、 模拟用户操作

>>> label.get_attribute("type") # 显示标签的type属性 name type id placeholder
>>> label.tag_name() #获取标签名字 input p form …… >>> label.size
>>> label.id >>> chrome_obj.maximize_window()# 窗口最大化
>>> #模拟鼠标悬浮
>>> label.click() # 模拟a标签  点击事件
>>> label.send_keys("模拟搜索内容") # 模拟input框 输入内容
>>> label.clear() # 清除input标签中 输入的内容 >>> chrome_obj.back() # 模拟浏览器 返回上一个浏览页面

  

 

1、模拟鼠标操作

from selenium.webdriver.common.action_chains import ActionChains #导入模块

>>> label = chrome_obj.find_element_by_link_text("点我 悬浮 显示其他 a标签")

>>> ActionChains(chrome_obj).move_to_element(label).perform()    # 模拟用户悬浮    
"""  ActionChains(chrome_obj) 用于生成模拟用户行为 ;
    perform()  执行存储行为  """
>>> label_bel = chrome_obj.find_element_by_link_text("我是 a标签,点我页面跳转")
>>> label_bel.click() # 模拟用户点击

 其他鼠标操作

label.countext_lick() # 右击
label.double_click() # 双击
label.drag_and_drop() # 拖动
label.move_to_element # 悬浮
label.click_and_hold # 按鼠标左键一直不动

  

2、模拟键盘操作

from selenium.webdriver.common.keys import Keys  #  引入模块

>>> label.send_keys("input输入的内容")

>>> label.send_keys(Keys.BACK_SPANCE)  # 退格键

>>>label.send_keys(Keys.CONTRL,'a')  # 全选

>>>label.send_keys(Keys.CONTRL,'v')  # 粘贴

>>>label.send_keys(Keys.CONTRL,'c')  # 复制

>>>label.send_keys(Keys.CONTRL,'x‘’) # 剪切

>>>label.send_keys(Keys.ENTER)   # 回车

  

四、处理对话框

python脚本实现自动登录

from selenium import webdriver
import time def automatic_login(name,pwd,url):
chrome = webdriver.Chrome()
chrome.get(url) time.sleep(2) chrome.maximize_window() time.sleep(5) chrome.find_element_by_xpath("/html/body/div[3]/div[2]/div[3]/div/div").click() chrome.find_element_by_link_text("登录").click()
time.sleep(5) name_label = chrome.find_element_by_id("id_account_l")
name_label.clear()
name_label.send_keys(name) pwd_label = chrome.find_element_by_id("id_password_l")
pwd_label.clear()
pwd_label.send_keys(pwd) time.sleep(5) login_label = chrome.find_element_by_id("login_btn")
login_label.click() time.sleep(15)
chrome.close() if __name__ == "__main__":
name = "helloyiwantong@163.com"
pwd = "helloyiwantong@1234"
url = "http://www.maiziedu.com/"
automatic_login(name,pwd,url)

python automatic login

五、控制多窗口

  

 >>> frome selenium import webdrive

>>> chrome  = webdrive.Chrome()

>>> chrome.get("https://www.baidu.come")

>>> chrome.find_element_by_id("kw").send_keys("红花")

>>> chrome.find_element_by_id("su").click()   # 打开百度搜索的第一个窗口

>>> chrome.find_element_by_partial_link_text("百度百科").click() # 打开第二个窗口

>>> chrome.find_element_by_partial_link_text("中药").click()  # 打开第三个窗口

>>> chrome.window_handles  # 查看当前 打开窗口

['CDwindow-D41F1F3BF5038E36E91EA7F7E7E9770D',

'CDwindow-F2D1553323BDC39BE99DBF280804FCCC',

'CDwindow-B41B29B8A7CB49BF191E46FF936E6A52',]

>>> chrome.switch_to_window(chrome.window_handles[1])  # 使用索引切换到第二个窗

>>> chrome.current_url()  # 查看当前url

六、模拟用户自动登录

from selenium import webdriver
import time
from selenium.webdriver.support.ui import WebDriverWait def wait_response_time(chrome,waittime,func):
# 返回 func执行结果
return WebDriverWait(chrome,waittime).until(func) def automatic_login(name,pwd,url):
chrome = webdriver.Chrome()
chrome.get(url) time.sleep(2) chrome.maximize_window() # time.sleep(2)
# chrome.find_element_by_xpath("/html/body/div[3]/div[2]/div[3]/div/div").click()
############## 第二种方法 设置时间延迟
# login_btn_lable = wait_response_time(chrome,5,
# lambda chrome: chrome.find_element_by_xpath("/html/body/div[3]/div[2]/div[3]/div/div"))
# login_btn_lable.click() ## 利用函数设置等待响应时间 chrome.find_element_by_link_text("登录").click()
time.sleep(1) name_label = chrome.find_element_by_id("id_account_l")
name_label.send_keys(" ") # 防止发送不成功
name_label.clear()
name_label.send_keys(name) pwd_label = chrome.find_element_by_id("id_password_l")
pwd_label.clear()
pwd_label.send_keys(pwd) time.sleep(5) login_label = chrome.find_element_by_id("login_btn")
login_label.click() error_id="login-form-tips"
error_message=chrome.find_element_by_id(error_id)
err=error_message.text
print(error_message,type(error_message))
print(err) # time.sleep(10)
# chrome.close() if __name__ == "__main__":
name = "helloyiwantong@163.com"
pwd = "helloyiwantong@134"
url = "http://www.maiziedu.com/"
automatic_login(name,pwd,url)

automatic login

七、模拟用户自动登录 封装接口

from selenium import webdriver
import time
from selenium.webdriver.support.ui import WebDriverWait def open_browse():
"""
open browser obj
:return:
"""
browse_obj = webdriver.Chrome()
return browse_obj def click_url_and_clicl_loginbtn(browse,url): """
open url and click "登录" btn
:param browse:
:param url:
:return:
"""
browse.get(url)
browse.maximize_window()
loginbtn_lable=browse.find_element_by_link_text("登录")
loginbtn_lable.click()
time.sleep(1) def get_element_label(browse,element_id_dict):
"""
get element lable
:param browse:
:param element_id_dict:
:return:
"""
user_label = browse.find_element_by_id(element_id_dict["name"])
pwd_label = browse.find_element_by_id(element_id_dict.get("pwd"))
login_label = browse.find_element_by_id(element_id_dict.get("login"))
return (user_label,pwd_label,login_label) def send_key_s(lable_tuple,userinfo_dict,userinfo_list):
"""
send userinfo and logian
:param lable_tuple:
:param userinfo_dict:
:param userinfo_list:
:return:
""" i=0
if i<=1:
for key in userinfo_list:
# lable_tuple[i].send_keys(" ")
# lable_tuple[i].click()
lable_tuple[i].send_keys(userinfo_dict.get(key))
i+=1
time.sleep(1) lable_tuple[2].click() ### 封装数据 url = "http://www.maiziedu.com/"
id_dict = {
"name":"id_account_l",
"pwd" : "id_password_l",
"login":"login_btn",
} userinfo_dict={
"name" : "helloyiwantong@163.com",
"pwd" : "helloyiwantong@1234",
"url" : "http://www.maiziedu.com/",
} # 函数使用 userinfo_list =["name","pwd"] chrome = open_browse()
click_url_and_clicl_loginbtn(chrome,url) lable_tuple = get_element_label(chrome,id_dict) send_key_s(lable_tuple,userinfo_dict,userinfo_list)

automatic login

自动化测试 selenium 模块 webdriver使用(一)的更多相关文章

  1. 自动化测试 selenium中WebDriver 和WebElement的区别

    之前在做UI自动化测试中 经常会用到  WebDriver  和 WebElement两个类   以前对这两个类总感觉有点傻傻分不清 昨天看了下之前下的代码  结合自己的理解  对着两个类的区别和关系 ...

  2. 安装自动化测试工具webdriver与selenium模块

    webdriver是一个驱动,需要与selenium配合使用,selenium是自动化测试和爬虫的专业模块,对于不同的浏览器需要不同的webdriver,这里我用的是ubuntu19.10的系统,以p ...

  3. 爬虫(五)—— selenium模块启动浏览器自动化测试

    目录 selenium模块 一.selenium介绍 二.环境搭建 三.使用selenium模块 1.使用chrome并设置为无GUI模式 2.使用chrome有GUI模式 3.查找元素 4.获取标签 ...

  4. Selenium(Webdriver)自动化测试常问问题

    http://blog.sina.com.cn/s/blog_c189e2590102w3bv.html Selenium(Webdriver)自动化测试常问问题 (1)selenium中如何保证操作 ...

  5. 自动化测试-Selenium家谱介绍

    一.自动化测试定义 自动化测试是通工具录制或编写脚本的方式模拟手工测试的过程,通过回放或运行脚本来执行测试用例,从而代替人工对系统的功能进行验证. 二.什么样的项目适合做自动化测试 1.需求明确,不会 ...

  6. 爬虫基础(三)-----selenium模块应用程序

    摆脱穷人思维 <三> :  培养"目标导向"的思维:  好项目永远比钱少,只要目标正确,钱总有办法解决. 一 selenium模块 什么是selenium?seleni ...

  7. 爬虫之selenium模块

    Selenium 简介 selenium最初是一个自动化测试工具,而爬虫中使用它主要是为了解决requests无法直接执行JavaScript代码的问题 selenium本质是通过驱动浏览器,完全模拟 ...

  8. 爬虫-----selenium模块自动爬取网页资源

    selenium介绍与使用 1 selenium介绍 什么是selenium?selenium是Python的一个第三方库,对外提供的接口可以操作浏览器,然后让浏览器完成自动化的操作.     sel ...

  9. Selenium:WebDriver简介及元素定位

    参考内容:官方API文档,下载链接:http://download.csdn.net/detail/kwgkwg001/4004500 虫师:<selenium2自动化测试实战-基于python ...

随机推荐

  1. 35个高级Python知识点总结

    原文地址:https://blog.51cto.com/xvjunjie/2156525 No.1 一切皆对象 众所周知,Java中强调“一切皆对象”,但是Python中的面向对象比Java更加彻底, ...

  2. tab页签

    <div class="fl" id="newsBox"> <div class="tab1 grayBar"> & ...

  3. 前端接收 post 请求返回的文件

    坐标过多无法用Get请求,只能用post下载. 但发现ajax发送的post请求没有触发下载,返回的流媒体会存在于接口返回的response中. 查询发现AJAX并不会唤起浏览器的下载窗口,AJAX设 ...

  4. 最新 满帮java校招面经 (含整理过的面试题大全)

    从6月到10月,经过4个月努力和坚持,自己有幸拿到了网易雷火.京东.去哪儿.满帮等10家互联网公司的校招Offer,因为某些自身原因最终选择了满帮.6.7月主要是做系统复习.项目复盘.LeetCode ...

  5. laravel的定时任务

    首先在laravel项目命令创建: php artisan make:command TestCommand 会在App\Console\Commands文件下看到TestCommand.php文件, ...

  6. 在同一个页面多次调用el-select选择器

    elementui是一个十分好用的组件库,但毕竟也不能做到面面俱到,有些还是要根据根据自己的实际需求做一些自定义的方法. 比如el-select选择器在同一个页面使用多次的话就会造成选择一个另一个也会 ...

  7. jqGrid全部选中

    var jqGrid = $("#jqGrid"); // 拿到所有行id var jqGridIDs = jqGrid.getDataIDs(); // 拿到所有选中行id va ...

  8. 乐字节Java反射之一:反射概念与获取反射源头class

    一.Java反射机制概念 “程序运行时,允许改变程序结构或变量类型,这种语言称为动态语言”,如Python, Ruby是动态语言:显然C++,Java,C#不是动态语言,但是JAVA有着一个非常突出 ...

  9. [转帖]新手必读,16个概念入门 Kubernetes

    新手必读,16个概念入门 Kubernetes https://www.kubernetes.org.cn/5906.html 2019-09-29 22:13 中文社区 分类:Kubernetes教 ...

  10. Elasticsearch集群搭建笔记(elasticsearch-6.3.0)

    # 检查Java版本 java -version # 安装Elasticsearch,所有节点均安装并解压 wget https://artifacts.elastic.co/downloads/el ...