首页 > Python资料 博客日记
小袁口算python
2024-11-03 06:00:04Python资料围观93次
这篇文章介绍了小袁口算python,分享给大家做个参考,收藏Python资料网收获更多编程知识
pyhton纯视觉方案,按照模拟器位置捕捉截图进行比较,为两张截图方案,自行更改位置,需要下载pytesseract ocr到本机,同时需更改捕捉屏幕的区域,go字样的区域,仅供学习,刷速度此方案不可行
import cv2
import pytesseract
import pyautogui
import numpy as np
import time
from concurrent.futures import ThreadPoolExecutor
# Tesseract OCR路径配置
pytesseract.pytesseract.tesseract_cmd = r'C:\Program Files\Tesseract-OCR\tesseract.exe'
def capture_screenshot(region=None):
# 捕捉屏幕截图
screenshot = pyautogui.screenshot(region=region) # 捕捉指定区域
img = np.array(screenshot) # 转换为numpy数组
img = cv2.cvtColor(img, cv2.COLOR_RGB2BGR) # 转换为BGR格式
return img
def extract_text_from_image(img):
# 图像中提取文本
custom_config = r'--oem 3 --psm 6' # Tesseract配置
text = pytesseract.image_to_string(img, config=custom_config)
print("识别出的文本:", text) # 调试输出
return text.strip()
def wait_for_go(region):
# 等待识别到go字样后继续执行
print("等待识别到 'go' 字样...")
while True:
img = capture_screenshot(region)
text = extract_text_from_image(img)
if 'go' in text.lower(): # 如果识别到 "go",开始执行主程序
print("'go' 已识别,开始执行主程序")
break
time.sleep(0.1) # 每秒检查一次
def extract_number_from_image(img):
# 从图像中提取数字
custom_config = r'--oem 3 --psm 6 outputbase digits' # Tesseract配置
details = pytesseract.image_to_data(img, output_type=pytesseract.Output.DICT, config=custom_config)
# 提取识别出的文本信息
numbers = []
for i, text in enumerate(details['text']):
if text.isdigit(): # 只提取数字
numbers.append(int(text))
print("提取的数字:", numbers) # 调试输出
return numbers
def draw_comparison_sign(result, start_position):
# 模拟鼠标滑动绘制比较符号
pyautogui.moveTo(start_position[0], start_position[1]) # 移动到起始位置
# 绘制符号
if result == ">":
# 绘制大于号
pyautogui.dragTo(210, 710, button='left', duration=0.00001) # 上半部分
pyautogui.dragTo(200, 720, button='left', duration=0.00001) # 下半部分
elif result == "<":
# 绘制小于号
pyautogui.dragTo(190, 710, button='left', duration=0.00001) # 上半部分
pyautogui.dragTo(200, 720, button='left', duration=0.00001) # 下半部分
def process_image(region):
# 捕捉图像并提取数字
img = capture_screenshot(region)
numbers = extract_number_from_image(img)
return numbers
def main(region1, region2):
#主循环 捕捉、识别、比较并绘制符号
iterations = 13 # 设定循环次数
with ThreadPoolExecutor(max_workers=2) as executor: # 创建线程池,设置2个并发工作线程
for i in range(iterations):
# 使用线程并行处理两个图像捕捉与数字提取
future1 = executor.submit(process_image, region1)
future2 = executor.submit(process_image, region2)
# 获取提取结果
numbers1 = future1.result()
numbers2 = future2.result()
if len(numbers1) > 0 and len(numbers2) > 0:
num1 = numbers1[0] # 假设第一张图像提取第一个数字
num2 = numbers2[0] # 假设第二张图像提取第一个数字
print(f"第一张识别到数字: {num1},第二张识别到数字: {num2}")
# 比较数字并绘制符号
if num1 > num2:
draw_comparison_sign(">", (200, 700)) # 在指定位置绘制大于号
elif num1 < num2:
draw_comparison_sign("<", (200, 700)) # 在指定位置绘制小于号
else:
print("两个数字相等,无需绘制符号。")
time.sleep(0.3) # 暂停0.5秒再进行下一次截图
# 示例:定义捕捉屏幕的区域
region1 = (100, 300, 100, 100) # 第一张图像捕捉区域 (x, y, width, height)
region2 = (290, 310, 100, 100) # 第二张图像捕捉区域 (x, y, width, height)
# 定义 'go' 字样的区域
go_region = (190, 425, 120, 65) # 假设 'go' 字样出现在这个区域 (x, y, width, height)
# 等待识别到 'go' 字样后启动主程序
wait_for_go(go_region)
# 启动主程序
try:
main(region1, region2)
except KeyboardInterrupt:
print("程序已停止")
except Exception as e:
print("发生错误:", e)
版权声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
标签:
相关文章
最新发布
- 光流法结合深度学习神经网络的原理及应用(完整代码都有Python opencv)
- Python 图像处理进阶:特征提取与图像分类
- 大数据可视化分析-基于python的电影数据分析及可视化系统_9532dr50
- 【Python】入门(运算、输出、数据类型)
- 【Python】第一弹---解锁编程新世界:深入理解计算机基础与Python入门指南
- 华为OD机试E卷 --第k个排列 --24年OD统一考试(Java & JS & Python & C & C++)
- Python已安装包在import时报错未找到的解决方法
- 【Python】自动化神器PyAutoGUI —告别手动操作,一键模拟鼠标键盘,玩转微信及各种软件自动化
- Pycharm连接SQL Sever(详细教程)
- Python编程练习题及解析(49题)
点击排行
- 版本匹配指南:Numpy版本和Python版本的对应关系
- 版本匹配指南:PyTorch版本、torchvision 版本和Python版本的对应关系
- Python 可视化 web 神器:streamlit、Gradio、dash、nicegui;低代码 Python Web 框架:PyWebIO
- 相关性分析——Pearson相关系数+热力图(附data和Python完整代码)
- Anaconda版本和Python版本对应关系(持续更新...)
- Python与PyTorch的版本对应
- Windows上安装 Python 环境并配置环境变量 (超详细教程)
- Python pyinstaller打包exe最完整教程