python自动化实现的简单使用

目录
  • 环境配置
  • 定位
    • 1.Link_text定位超链接
    • 2.混合元素定位
    • 3.Xpath定位(通常)
    • 4.css定位
  • 操作
    • 1.实现输入框自动输入
    • 2.清空输入框
    • 3.上传文件
    • 4.自动化执行javaScript方法
    • 5.浏览器窗口切换
    • 6.切换ifame
    • 7.alert窗口切换
    • 8.模拟鼠标经过操作
    • 9.模拟拖拽操作?
    • 10.隐式等待?
    • 11.显示等待?
  • 测试
    • 1.自动填写登录csdn
    • 2.隐式登录百度地图?

环境配置

  • pycharm环境配置
  • 下载chrome drives.exe,版本选择要和chrome浏览器版本相近放在python目录script
  • 在pycharm输入以下代码使python配合seninum实现自动化输入

定位

1.Link_text定位超链接

from selenium import webdriver

#创建浏览器
driver = webdriver.Chrome()
driver.get("https://www.baidu.com")

#根据linktext方法定位超链接属性界面字样"新闻",看是否打开新闻超链接(注意link_text值用单引号)
#driver.find_element_by_link_text('新闻').click()

#根据partial_linktext方法定位超链接属性界面模糊字样"地",看是否打开地图超链接
driver.find_element_by_partial_link_text('地').click()

import time
# 沉睡的目的是让程序进行地慢一点方便观看,有时候是等待元素渲染完成
time.sleep(5)

#关闭浏览器
#driver.quit()

2.混合元素定位

a.属性定位方式

#查找所有id=root的元素
driver.find_element_by_xpath('//*[@id="root"]

b.查找所有id值包含"con"的所有元素

注:contains()是个函数
//*[contains(@id,"con")]

c.查找所有包含id=footerLayer 且 包含class=relativeFooterLayer的所有元素

//*[@id="footerLayer" and @class="relativeFooterLayer" ]

d. 查找所有包含id=footerLayer 或者 包含class=relativeFooterLayer的所有元素

/*[@id="footerLayer" or @class="relativeFooterLayer" ]

f.查找 class以mod开头的div属性

//div[starts-with(@class,'mod')]

3.Xpath定位(通常)

1.绝对定位

从顶层一层一层往下找对应的元素
缺点:页面改动,绝对地址就会发生改变,将会定位错误

from selenium import webdriver
import time

#创建浏览器
driver = webdriver.Chrome()
driver.get("https://www.ctrip.com/")

#使用xpath方法绝对定位点击携程的攻略.景点功能
driver.find_element_by_xpath('/html/body/div/div[@id="leftSideNavLayer"]/div/div/div[@style]/div/div/div/div[6]').click()
#沉睡的目的是让程序进行地慢一点方便观看,有时候是等待元素渲染完成
sleep(2)

#关闭浏览器
driver.quit()

相对定位(经常)

from selenium import webdriver
import time

#创建浏览器
driver = webdriver.Chrome()
driver.get("https://www.ctrip.com/")

#使用xpath方法模糊定位点击携程的攻略.景点功能
driver.find_element_by_xpath('//body//div[@id="root"]//div[@class="lsn_first_nav_wrap_LZamG"][5]').click()

#沉睡的目的是让程序进行地慢一点方便观看,有时候是等待元素渲染完成
sleep(2)

#关闭浏览器
driver.quit()

4.css定位

注意:

1.空格是跨越一级或多级元素

2.>表示下层子标签

3.属性:nth-child(1) ,表示相同属性第一个

#表示id

查找所有id=ie-update的元素
#ie-update

.表示class

查找所有class=lsn_first_nav_wrap_LZamG的元素
.lsn_first_nav_wrap_LZamG

事例

为了定位小米note 11T pro+的价格

#表示定位class值是brick-list clearfix的ul标签之下的li标签,跨越多个层级下class名为price的p标签,下的span标签
ul[class="brick-list clearfix"]>li p.price>span

操作

1.实现输入框自动输入

#此操作会自动打开浏览器,百度网址,输入"你还好吗","你怎么样了","你今天过的怎么样,充实吗?"其中之一,而且加载时间会变慢五秒,完成以上结果后,会自动关闭页面

from selenium import webdriver

#创建浏览器
driver = webdriver.Chrome()
driver.get("https://www.baidu.com")

#根据id属性定位元素
#driver.find_element_by_id('kw').send_keys("你还好吗")

#根据class属性定位元素
#driver.find_element_by_class_name('s_ipt').send_keys("你怎么样了")

#根据name属性定位元素
driver.find_element_by_name('wd').send_keys("你今天过的怎么样,充实吗?")

import time
#沉睡的目的是让程序进行地慢一点方便观看,有时候是等待元素渲染完成
time.sleep(5)

#关闭浏览器
driver.quit()

2.清空输入框

from selenium import webdriver
import time

#创建浏览器,打开百度输入框
driver = webdriver.Chrome()
driver.get("https://www.baidu.com/")

#定义变量th为输入框
th=driver.find_element_by_id('kw')

#在输入框中输入文字,清空,再输入
time.sleep(3)
th.send_keys("说不完的话.....")
time.sleep(1)
th.clear()
th.send_keys("你还好吗")

time.sleep(2)

#关闭浏览器
driver.quit()

3.上传文件

百度自动上传图片搜索

from selenium import webdriver
import time

#创建浏览器
driver=webdriver.Chrome()
#浏览器输入百度网址
driver.get("https://www.baidu.com/")

#点击上传按钮
driver.find_element_by_xpath('/html/body/div[1]/div[1]/div[5]/div/div/form/span[1]/span[1]').click()
#点击选择文件
driver.find_element_by_xpath('/html/body/div[1]/div[1]/div[5]/div/div/form/div/div[2]/div[2]/input').send_keys('C:\\Users\\hhh\\Desktop\\百度元素.png')

time.sleep(6)
driver.quit()

4.自动化执行javaScript方法

在f12下console下输入以下代码

#因为日期每月的每天位置都不一样,所以引入了document.querySelector()方法
#来查找class名为td的标签中的id值是"June-29-2022"
#所以若想点击其他日期,直接改变id值就行

document.querySelector('[class="pi-input J_DepDate has-trans trigger-node-406"]').placeholder="2022-3-15"

在python下执行javaScript格式

driver.execute_script('document.querySelector(\'[class="pi-input J_DepDate has-trans trigger-node-406"]\').placeholder="2022-3-15"')

5.浏览器窗口切换

from selenium import webdriver
import time

#创建浏览器,打开百度输入框
driver = webdriver.Chrome()
driver.get("https://www.baidu.com/")

#在输入框中搜索
driver.find_element_by_id('kw').send_keys("hello,world")
time.sleep(2)

#点击搜索
driver.find_element_by_id('su').click()

#点击文本的百度百科
driver.find_element_by_xpath('//div[@class="bk_polysemy_1Ef6j"]//a').click()

time.sleep(5)

 #获取所有的浏览器窗口
 windows=driver.window_handles

 #选中第二个新开的浏览器窗口
 driver.switch_to.window(windows[-1])

#切换到第一个浏览器窗口
driver.switch_to.window(windows[0])

6.切换ifame

为什么要切换ifame

原因是网页嵌套一个网页,不切换ifame,定位不到元素

from selenium import webdriver
import time

#创建浏览器,打开阿里云注册界面
driver = webdriver.Chrome()
driver.get("https://account.aliyun.com/register/qr_register.htm")

#定义一个变量frame  ,值是定位frame元素
frame = driver.find_element_by_id('alibaba-register-box')

#切到html下frame页面
driver.switch_to.frame(frame)

#在注册界面账号栏输入账号
driver.find_element_by_xpath('//div[@class=" next-form-item-control"]//input').send_keys("17655870668")

#在注册界面账号栏输入密码
driver.find_element_by_xpath('//div[@class="pwd-wrap"] //input[@type="password"]').send_keys("edwdaf")

#再次切换到frame外层
driver.switch_to.parent_frame()

time.sleep(3)
driver.quit()

7.alert窗口切换

from selenium import webdriver
import time

#创建浏览器
driver = webdriver.Chrome()
#打开我的本地弹窗html文件
driver.get("E:\\python_pro\\venv\\1.html")

#定义一个变量用于弹出的alert窗口
alert = driver.switch_to.alert

print(alert.text)

time.sleep(3)
driver.quit()

8.模拟鼠标经过操作

from selenium import webdriver
import time
#引入 ActionChains类
from selenium.webdriver.common.action_chains import ActionChains

#创建浏览器
driver = webdriver.Chrome()
#打开京东界面
driver.get("https://www.jd.com")
time.sleep(3)

#定义一个变量m用于接收"网站导航"定位
m = driver.find_element_by_xpath('//*[@aria-label="网站导航"]')
#传入变量m,并使鼠标悬停在"网站导航"
ActionChains(driver).move_to_element(m).perform()#perform()方法代表执行的意思

time.sleep(3)

#定义一个变量x用于接收"京东通信"定位
x = driver.find_element_by_xpath('//a[@role="menuitem" and text()="京东通信"]')
#传入变量x,并使鼠标点击悬停在"网站导航"的"京东通信"子页面
ActionChains(driver).move_to_element(x).click().perform()

time.sleep(3)
driver.quit()

9.模拟拖拽操作?

from selenium import webdriver
import time
#引入 ActionChains类
from selenium.webdriver.common.action_chains import ActionChains

#创建浏览器
driver = webdriver.Chrome()
action= ActionChains(driver)

#打开地图界面
driver.get("https://map.baidu.com/@11590057.96,4489812.75,4z")
time.sleep(6)

time.sleep(3)
#定位地图的定位
u=driver.find_element_by_xpath('//*[@type="system"]')
#  move_to_element(mask)移动到这个元素,click_and_hold()按下鼠标,move_by_offset(50,30)偏移量拖动,release()松开鼠标,perform()执行操作
action.move_to_element(u).click_and_hold().move_by_offset(50,30).release().perform()

time.sleep(3)
driver.quit()

10.隐式等待?

为了解决一段时间页面弹出登录窗口

from selenium import webdriver
import time
#引入 ActionChains类
from selenium.webdriver.common.action_chains import ActionChains

#创建浏览器
driver = webdriver.Chrome()

#隐式等待页面元素时间(0-15s)
driver.implicitly_wait(15)
#打开地图界面
driver.get("https://map.baidu.com/@11590057.96,4489812.75,4z")

#记录开始时间
start_time = time.perf_counter()

#点击账号输入
driver.find_element_by_xpath('//*[@name="userName"]').send_keys('1321454654')
#点击密码输入
driver.find_element_by_xpath('//*[@name="password"]').send_keys('zawwe343234')
#点击登录
driver.find_element_by_xpath('//*[@value="登录"]').click()

action= ActionChains(driver)

#定位地图的定位
u=driver.find_element_by_xpath('//*[@type="system"]')
#  move_to_element(mask)移动到这个元素,click_and_hold()按下鼠标,move_by_offset(50,30)偏移量拖动,release()松开鼠标,perform()执行操作
action.move_to_element(u).click_and_hold().move_by_offset(50,30).release().perform()

time.sleep(3)
driver.quit()

11.显示等待?

可以控制单个元素等待时间

from selenium import webdriver
import time
#引入显示等待函数
import selenium.webdriver.support.expected_conditions as EC
from selenium.webdriver.common.by import By

#创建浏览器
driver = webdriver.Chrome()
#打开地图界面
driver.get("https://map.baidu.com/@11590057.96,4489812.75,4z")

#记录开始时间
#start_time = time.perf_counter()

WebDriverWait(driver,5).until(EC.presence_of_element_located(By.CSS_SELECTOR,'//*[@name="userName"]'))

#记录结束时间
#end_time = time.perf_counter()
#print(f'{end_time - start_time} s')

#点击账号输入
driver.find_element_by_xpath('//*[@name="userName"]').send_keys('345761231')
#点击密码输入
driver.find_element_by_xpath('//*[@type="password" and @name="password"]').send_keys('21323dwe')

# time.sleep(3)
# driver.quit()

测试

1.自动填写登录csdn

from selenium import webdriver
import time

#创建浏览器
driver=webdriver.Chrome()

#浏览器输入csdn网址
driver.get("https://www.csdn.net/?spm=1000.2115.3001.4476")
#找到超链接文本登录/注册,然后点击
driver.find_element_by_link_text('登录/注册').click()
#点击登录方式-密码登录
driver.find_element_by_xpath('/html/body/div[2]/div/div[2]/div[2]/div[1]/div[1]/div[1]/span[4]').click()

#输入csdn账号
driver.find_element_by_xpath('/html/body/div[2]/div/div[2]/div[2]/div[1]/div/div[2]/div/div[1]/div/input').send_keys('账号')
#输入csdn密码
driver.find_element_by_xpath('/html/body/div[2]/div/div[2]/div[2]/div[1]/div/div[2]/div/div[2]/div/input').send_keys('密码')
#登录
driver.find_element_by_xpath('/html/body/div[2]/div/div[2]/div[2]/div[1]/div/div[2]/div/div[4]/button').click()

time.sleep(10)
driver.quit()

2.隐式登录百度地图?

from selenium import webdriver
import time
#引入 ActionChains类
from selenium.webdriver.common.action_chains import ActionChains

#创建浏览器
driver = webdriver.Chrome()

#隐式等待页面元素时间(0-15s)
driver.implicitly_wait(5)
#打开地图界面
driver.get("https://map.baidu.com/@11590057.96,4489812.75,4z")

#记录开始时间
#start_time = time.perf_counter()

#点击账号输入
driver.find_element_by_xpath('//*[@name="userName"]').send_keys('423425465')
#点击密码输入
driver.find_element_by_xpath('//*[@type="password" and @name="password"]').send_keys('8vsdrw5')
# 点击登录
driver.find_element_by_xpath('//*[@value="登录" and @type="submit"]').click()

#记录结束时间
#end_time = time.perf_counter()
#print(f'{end_time - start_time} s')

action = ActionChains(driver)

#定位地图的定位
u=driver.find_element_by_xpath('//*[@type="system"]')
#move_to_element(mask)移动到这个元素,click_and_hold()按下鼠标,move_by_offset(50,30)偏移量拖动,release()松开鼠标,perform()执行操作
action.move_to_element(u).click_and_hold().move_by_offset(50,30).release().perform()

# time.sleep(3)
# driver.quit()

到此这篇关于python自动化实现的简单使用的文章就介绍到这了,更多相关python自动化 内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • python自动化实现登录获取图片验证码功能

    主要记录一下:图片验证码 1.获取登录界面的图片 2.获取验证码位置 3.在登录页面截取验证码保存 4.调用百度api识别(目前准确率较高的识别图片api) 本次登录的系统页面,可以看到图片验证码的位置 from selenium import webdriver import time from PIL import Image base_url = '***********' browser = webdriver.Chrome() browser.maximize_window() bro

  • python自动化测试实例解析

    本文实例讲述了python自动化测试的过程,分享给大家供大家参考. 具体代码如下: import unittest ######################################################################## class RomanNumeralConverter(object): """converter the Roman Number""" #-----------------------

  • python实现报表自动化详解

    本篇文章将介绍: xlwt 常用功能 xlrd 常用功能 xlutils 常用功能 xlwt写Excel时公式的应用 xlwt写入特定目录(路径设置) xlwt Python语言中,写入Excel文件的扩展工具.可以实现指定表单.指定单元格的写入.支持excel03版到excel2013版.使用时请确保已经安装python环境 xlrd Python语言中,读取Excel的扩展工具.可以实现指定表单.指定单元格的读取.使用时请确保已经安装python环境. NOTICE: xlwt对Excel只

  • Python自动化测试工具Splinter简介和使用实例

    Splinter 快速介绍 官方网站:http://splinter.cobrateam.info/ 官方介绍: Splinter is an open source tool for testingweb applications using Python. It lets you automate browser actions, such asvisiting URLs and interacting with their items 特性:1.可以模拟浏览器行为,访问指定的URL,并且可

  • Python PyAutoGUI模块控制鼠标和键盘实现自动化任务详解

    本文实例讲述了Python PyAutoGUI模块控制鼠标和键盘实现自动化任务.分享给大家供大家参考,具体如下: PyAutoGUI是用Python写的一个模块,使用它可以控制鼠标和键盘. 利用它可以实现自动化任务,再也不用担心有重复枯燥的任务了. pyautogui模块的功能: 移动鼠标.点击左右键和滚轮 发送虚拟按键 # 安装pyautogui 这个模块支持Windows, Mac OS X 和 Linux. 根据系统不同,你可能需要安装一些依赖. Linux系统(Debian系列): $

  • python3+selenium自动化测试框架详解

    背景 为了更好的发展自身的测试技能,应对测试行业以及互联网行业的迭代变化.自学python以及自动化测试. 虽然在2017年已经开始接触了selenium,期间是断断续续执行自动化测试,因为还有其他测试任务,培训任务要执行- 前期建议大家能够学习python基本语法(python基础教程) 任务 搭建自动化测试框架,并能有效方便的进行测试,维护成本也要考虑其中. 过程 我的自动化框架可能不成熟,因为是自学的.请多包涵.也请大佬指导~ common 包含:基本的公共方法类,比如HTML报告.Log

  • Python 自动化表单提交实例代码

    今天以一个表单的自动提交,来进一步学习selenium的用法 练习目标 0)运用selenium启动firefox并载入指定页面(这部分可查看本人文章 http://www.cnblogs.com/liu2008hz/p/6958126.html) 1)页面元素查找(多种查找方式:find_element_*) 2)内容填充(send_keys) 3)iframe与父页面切换(switch_to_frame是切换到iframe,switch_to_default_content是切换到主页面)

  • Python + selenium自动化环境搭建的完整步骤

    前言 本文主要介绍了关于Python+selenium自动化环境搭建的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧 Python +selenium+googledriver 小白的血泪安装使,不停的总结写心得是理解透彻的毕竟之路 一,python的安装: 首先去Python的官网下载安装包:https://www.python.org/  ,大家也可以通过我们进行下载://www.jb51.net/softs/415916.html 2.下载完成后如下图所示 3.双

  • selenium+python实现自动化登录的方法

    Selenium Python 提供了一个简单的API 便于我们使用 Selenium WebDriver编写 功能/验收测试. 通过Selenium Python的API,你可以直观地使用所有的 Selenium WebDriver 功能 .Selenium Python提供了一个很方便的接口来驱动 Selenium WebDriver , 例如Firefox.Chrome.Ie,以及Remote,目前支持的python版本有2.7或3.2以上. selenium 可以自动化测试.抢票.爬虫等

  • python自动化实现的简单使用

    目录 环境配置 定位 1.Link_text定位超链接 2.混合元素定位 3.Xpath定位(通常) 4.css定位 操作 1.实现输入框自动输入 2.清空输入框 3.上传文件 4.自动化执行javaScript方法 5.浏览器窗口切换 6.切换ifame 7.alert窗口切换 8.模拟鼠标经过操作 9.模拟拖拽操作? 10.隐式等待? 11.显示等待? 测试 1.自动填写登录csdn 2.隐式登录百度地图? 环境配置 pycharm环境配置 下载chrome drives.exe,版本选择要

  • Selenium+Python 自动化操控登录界面实例(有简单验证码图片校验)

    从最简单的Web浏览器的登录界面开始,登录界面如下: 进行Web页面自动化测试,对页面上的元素进行定位和操作是核心.而操作又是以定位为前提的,因此,对页面元素的定位是进行自动化测试的基础. 页面上的元素就像人一样,有各种属性,比如元素名字,元素id,元素属性(class属性,name属性)等等.webdriver就是利用元素的这些属性来进行定位的. 可以用于定位的常用的元素属性: id name class name tag name link text partial link text xp

  • 十个简单使用的Python自动化脚本分享

    目录 1.给照片添加水印 2.检测文本文件的相似性 3.对文件内容进行加 密 4.将照片转换为PDF 5.修改照片的长与宽 6.对于照片的其他操作 7.测试网速 8.货币汇率的转换 9.生成二维码 10.制作一个简单的网页应用 在日常的工作学习当中,我们总会遇到各式各样的问题,其中不少的问题都是一遍又一遍简单重复的操作,不妨直接用Python脚本来自动化处理,今天小编就给大家分享十个Python高级脚本,帮助我们减少无谓的时间浪费,提高工作学习中的效率. 1.给照片添加水印 给照片添加水印的代码

  • python 自动化将markdown文件转成html文件的方法

    一.背景 我们项目开发人员写的文档都是markdown文件.对于其它组的同学要进行阅读不是很方便.每次编辑完markdown文件,我都是用软件将md文件转成html文件.刚开始转的时候,还没啥,转得次数多了,就觉得不能继续这样下去了.作为一名开发人员,还是让机器去做这些琐碎的事情吧.故写了两个脚本将md文件转成html文件,并将其放置在web服务器下,方便其他人员阅读. 主要有两个脚本和一个定时任务: •一个python脚本,主要将md文件转成html文件: •一个shell脚本,主要用于管理逻

  • Appium+python自动化之连接模拟器并启动淘宝APP(超详解)

    简介 上一篇讲解完模拟器的安装.配置好以后,就好比我们手机已经买好,并且系统已经做好了,就差我们用数据线和电脑连接开始实战了,这篇宏哥就带着小伙伴们和童鞋们趁热打铁,讲解和分享一下如何连接模拟器(电脑版的虚拟手机),然后再安装一款APP-淘宝为例. 一.appium+pycharm+连接夜神模拟器并启动淘宝APP(推荐) 1.首先打开pycharm并写好代码,这里以淘宝APK作为测试Demo,淘宝APK我是放在电脑桌面(或者放置同代码同个目录下).如下图所示 其中|:driver = webdr

  • python自动化测试之DDT数据驱动的实现代码

    时隔已久,再次冒烟,自动化测试工作仍在继续,自动化测试中的数据驱动技术尤为重要,不然咋去实现数据分离呢,对吧,这里就简单介绍下与传统unittest自动化测试框架匹配的DDT数据驱动技术. 话不多说,先撸一波源码,其实整体代码并不多 # -*- coding: utf-8 -*- # This file is a part of DDT (https://github.com/txels/ddt) # Copyright 2012-2015 Carles Barrobés and DDT con

  • python自动化UI工具发送QQ消息的实例

    概述 个人遇到过小的需求,windows自动水群发送垃圾消息,使用一些特别简单易上手的小工具,快速实现功能需求(而不是使用一些重量级的还需要额外花时间去熟悉功能语法的大工具,如UI自动化工具sikulix).在一番摸索下,得出一番结论: 对于多平台的UI自动复杂操作,还是去学sikulix吧,这不是啃一点win32 api获取窗口句柄就能轻松解决的,毕竟sikulix是MIT大佬折腾出来的.而且,原理也更复杂(通过使用opencv对窗体控件进行识别,进而实现控制操作). 对于简单的操作(控制剪切

  • python自动化报告的输出用例详解

    1.设计简单的用例 2.设计用例 以TestBaiduLinks.py命名 # coding:utf-8 from selenium import webdriver import unittest class BaiduLinks(unittest.TestCase): def setUp(self): base_url = 'https://www.baidu.com' self.driver = webdriver.Chrome() self.driver.implicitly_wait(

  • Python自动化之UnitTest框架实战记录

    1 UnitTest 基本用法 UnitTest 框架是 Python 自带的一个作为单元测试的测试框,相当于 Java中的 JUnit,随着自动化技术的成熟,UnitTest 成为了测试框架第一选择,可以完整的结合 Selenium.Requests 来实现 Ul 和接口的自动化,由 UnitTest 再衍生出 PyTest,PyTest 可以完美结合 UnitTest 来实现自动化. 基本应用: 1.环境搭建,Python 中已经直接加载了 UnitTest 框架,无须额外安装 2.四大组件

随机推荐