OpenCV和selenum实现点击操作
import cv2 as cv
import numpy as np
from PIL import Image, ImageDraw, ImageFont
import os
from selenium.webdriver.common.action_chains import ActionChains
from selenium import webdriver as driver1
resultlist = []
device = 'PC'
path = os.path.abspath('..')
imglist = []
show =1
url="http://www.bjjs.gov.cn/bjjs/index/index.shtml"
driver = driver1.Chrome(executable_path=path+"/Program/chromedriver")
"""
首先:加载原始图像和要搜索的图像模板
其次:OpenCV对原始图像进行处理,创建一个灰度版本
再次:在灰度图像里进行处理和查找匹配
最后:使用相同的坐标在原始图像中进行还原并输出
"""
def opencv_elementActive(value=0.8, type='OK', msg='流程', title='测试_冀', desc='北京建房委员会', devices='PC'):
try:
target = path+r"\Run\Demo2\pic\PC\BJ_GOV\background\img.png"
temp = r"C:\Users\lenovo\Desktop\newI\UI\temp.png"
# 加载原始的RGB图像
img_rgb = cv.imread(target)
# 色彩空间转换(因为在opencv中默认的颜色空间是BGR)
# 创建一个原始图像的灰度版本,所有操作在灰度版本中处理
img_gray = cv.cvtColor(img_rgb, cv.COLOR_BGR2GRAY)
# 加载将要搜索的图像模板
template = cv.imread(temp, 0)
# 高斯函数对图形进行高斯滤波
merged = cv.GaussianBlur(np.uint8(np.clip((1.0 * img_rgb - 60), 0, 200)), (0, 0), 3)
# shape 图片的尺寸
w, h = template.shape[::-1]
# 使用matchTemple对原始灰度图像和图像模板进行匹配(在原始图像中查找并匹配图像模板中的内容,并设置阈值)
res = cv.matchTemplate(img_gray, template, cv.TM_CCOEFF_NORMED)
threshold = value
pt = []
except Exception as e:
print(" Error:",e)
try:
loc = np.where(res >= threshold)
# 使用灰度图像中的坐标对原始RGB图像进行标记
for pt in zip(*loc[::-1]):
cv.rectangle(img_rgb, pt, (pt[0] + w, pt[1] + h), (0, 30, 255), 10)
cropImg=img_rgb[pt[1]:pt[1] + h,pt[0]:pt[0] + w]
merged[pt[1]:pt[1] + h,pt[0]:pt[0] + w] = cropImg
creatImgDebug(merged,pt,h)
x, y = eval("pt[0]+w/2,pt[1]+h/2")
click(x,y)
except Exception as e:
print("===================================================================================================")
def creatImgDebug(img_rgb, pt, h):
cv_im = cv.cvtColor(img_rgb, cv.COLOR_BGR2RGB)
# arary转换成image
pil_im = Image.fromarray(cv_im)
# 创建绘制对象
draw = ImageDraw.Draw(pil_im)
font = ImageFont.truetype(path + "/Program/FZYTK.TTF", 80, encoding="utf-8")
font1 = ImageFont.truetype(path + "/Program/FZYTK.TTF", 40, encoding="utf-8")
draw.text((80, 50), "图像识别 {}检测:成功".format("图片识别成功"), (40, 250, 50), font=font)
draw.text((pt[0], pt[1] + h + 20), "坐标位:%s,%s" % (pt[0], pt[1]), (250, 40, 1), font=font1)
cv_text_im = cv.cvtColor(np.array(pil_im), cv.COLOR_RGB2BGR)
cv.namedWindow("Target", 0)
cv.resizeWindow("Target", 1600, 900)
cv.moveWindow("Target", 10, 50)
cv.imshow("Target", cv_text_im) #创建一个窗口显示图片,第一个参数是窗口名字,第二个参数是读入的图片
cv.waitKey(1200)
cv.destroyWindow("Target") # 删除建立的全部窗口
def click(x,y):
actions = ActionChains(driver)
el = driver.find_element_by_xpath('/html/body')
actions.move_to_element_with_offset(el, x, y).perform()
actions.move_by_offset(0,0).click().perform()
driver.implicitly_wait(6)
def selenium_start():
driver.get(url)
driver.maximize_window()
driver.implicitly_wait(4)
def screenshot():
driver.save_screenshot(path+r"\Run\Demo2\pic\PC\BJ_GOV\background\img.png")
if __name__ == '__main__':
"""
第一步:启动浏览器,输入网址
第二步:截取图片,保存到相应路径
第三步:在大图上匹配小的图片
第四步:返回坐标,selenium点击操作
"""
selenium_start()
screenshot()
opencv_elementActive()
driver.close()
OpenCV和selenum实现点击操作的更多相关文章
- JS---DOM---点击操作---part1---20个案例
点击操作:------>事件: 就是一件事, 有触发和响应, 事件源 按钮被点击,弹出对话框 按钮---->事件源 点击---->事件名字 被点了--->触发了 弹框了---& ...
- JS---DOM---点击操作---节点的方式---案例
点击操作---节点的方式---案例 案例1:点击按钮,设置p变色---节点的方式做 <!DOCTYPE html> <html lang="en"> < ...
- c#使用UIA进行模拟点击操作
之前,我写过一篇c#使用spy进行模拟操作的文章,有朋友在留言中提到了UIA进行操作,今天也使用UIA重新实现一次对vnc窗体的控制测试. 实现目标 在server框内填入192.168.2.200 ...
- opencv中对图像的像素操作
1.对灰度图像的像素操作: #include<iostream> #include<opencv2/opencv.hpp> using namespace std; using ...
- 使用powershell/vbs自动化模拟鼠标点击操作
今天想做windows上的自动化,所以才有了模拟鼠标点击的需求,先考虑用powershell实现: 首先先安装一个名为“WASP”免费可用的Powershell扩展程序,下载地址:http://was ...
- AutoIT: 如何通过坐标相对位置来对无法识别的Menu以及GridView进行定位点击操作
一般情况下,GridView中的数据来自数据库,我们通过Windows Info,是无法获取GridView中的信息的.而软件定制的Menu,很多时候无法通过系统提供的WinMenuSelectIte ...
- Opencv YAML和XML格式文件操作详解
本系列文章由 @YhL_Leo 出品,转载请注明出处. 文章链接: http://blog.csdn.net/yhl_leo/article/details/47660943 本文参考Opencv 2 ...
- Android 微信UI 、点击操作
上一篇,我们介绍了微信界面的相关知识点.今天我们就来把微信的界面做出来. 首先我们新建一个layout-->LinearLayout-->weixin.xml 我们使用上中下线性布局,采用 ...
- 【Java】在JTable中设置鼠标监听器,点击操作对应数据
最终效果 鼠标点击JTable中任一数据,修改相应的信息. 确定点击的行和列 package com.dao; import java.awt.event.MouseAdapter; import j ...
随机推荐
- java之servlet入门操作教程一
这篇文章主要用来记录,进行servlet开发的一些简单操作步骤,帮助直接上手操作 准备: java环境配置:已配置(javac检验) myeclipse开发环境:已安装 tomcat服务器:已安装(或 ...
- MySQL 笔记整理(12) --为什么我的MySQL会“抖”一下?
笔记记录自林晓斌(丁奇)老师的<MySQL实战45讲> (本篇内图片均来自丁奇老师的讲解,如有侵权,请联系我删除) 12) --为什么我的MySQL会“抖”一下? 断更了一段时间,因为这几 ...
- 携程Apollo一键编译脚本+部署实现
系统编译安装 ubuntu16.11 java 1.8 系统规划 Portal共用 其它环境每个两台机器 mysql都做主从,所以每个环境的机器上都会安装admin 服务,config服务,以及一个m ...
- HTML文档命名规则
HTML文档是展示Web前段开发工程师成果的最好表示方式,为了便于文档规范化管理,在编写HTML文档时,必须遵循HTML文件命名规则. HTML文档命名规则如下: (1)文档的扩展名为htm或者htm ...
- Postman学习之【压力测试】
Postman请自行下载 下面是在网上随便抓了一个请求地址来做演示,把请求地址填入地址栏,此请求为GET请求.点击Send发送请求,请求结果将会在下方显示出来.每次的请求历史数据,会被记录下来,但是经 ...
- SQLserver数据库反编译生成Hibernate实体类和映射文件
一.建立项目和sqlserver数据库 eclipse,我使用的版本是neon3 二.Data Source Explorer 选择OK 在data source Explorer的Database ...
- [20190417]隐含参数_SPIN_COUNT.txt
[20190417]隐含参数_SPIN_COUNT.txt--//在探究latch spin计数之前,先简单探究_SPIN_COUNT.实际上oracle现在版本latch spin的数量不再是200 ...
- 随机排序std::vector,扑克牌,麻将类尤其合用
有些需要重新对std::vector对象重新排序,特别是游戏,例如说:扑克牌,麻将,抽奖等,C++标准已经为std::vector写好了随机排序的方式,这里做个笔记: #include <alg ...
- Luogu4655 [CEOI2017]Building Bridges
Luogu4655 [CEOI2017]Building Bridges 有 \(n\) 根柱子依次排列,每根柱子都有一个高度.第 \(i\) 根柱子的高度为 \(h_i\) . 现在想要建造若干座桥 ...
- springIOC原理加载过程
关于spring ,我以前学过很多次,也看过很多的书.以及博客,但是总是不得要领,这次我再学习一遍,在这里做点记录,如果不对的地方还请大家指正 Ioc: inverse of controller 控 ...