前言
老是玩回合制游戏的时候,心猿意马的平日任务令人不胜其烦
【美高梅开户网址】python实战教程之自动扫雷,回合制手游做使命嫌麻烦。玩问道的时候,大家期望能够自行刷道,玩梦幻希望能半自动做师门、捉鬼等等
后天作者就用Python教大家做3个有关回合制游戏的脚本,该脚本只好模拟鼠标键盘操作,并无法改改游戏数量。
作者:`Rest探路者`
源自:`
若果您必要贰个美好的读书沟通条件,那么您能够设想Python学习调换群:548377875;
要是你供给一份系统的上学材料,那么您能够考虑Python学习交换群:548377875。
引入:
历次玩回合制游戏的时候,顾后瞻前的平凡任务令人不胜其烦
玩问道的时候,大家希望可以自动刷道,玩梦幻希望能半自动做师门、捉鬼等等
上回(Python完成电影排名榜活动网盘下载(4)Cookies免登录+抓包下载)说到,一段时间内能开始展览多少次离线下载或许受限于验证码的输入。
在此有四个缓解方案,
前言
说明:
该外挂只可以模拟鼠标键盘操作,并不可能改改游戏数量
笔者这里运用的python2.7
开发工具是PyCharm
- 见招拆招 通过GUI优化验证码输入
不怕有验证码,在用户一直输入验证码的情景下也是高效的。而且能够借此读书Python是怎么样做出GUI程序的,学起来也会是很有价值的,参考
试验楼
给Python3爬虫做贰个界面
今后有空子只怕会写点类似的试行案例。 - 利用网盘客户端
以此化解方案的帮助和益处就是绝非!验!证!码!缺点正是添加的进程视财富而定,要是不合法能源较多,只怕会招致频仍重启;再有实在那便是个按键脚本,选拔模拟鼠标、键盘等操作,感觉相比脑残…
活动扫雷一般分为两种,一种是读取内部存款和储蓄器数据,而另一种是透过分析图片获得数量,并透过模拟鼠标操作,那里笔者用的是第一种方法。
付出条件准备
Python2.7 + Windows
模块:autopy,可pip install autopy
初期知识准备:
第1下载autopy包,作者那边PyCharm能够向来导入autopy包
照旧用利用pip进行安装:pip install autopy
那篇著作记录了自己第两种艺术的尝试进度,最终测试了多少个磁力链接的增速,大致是那样的:
一 、准备干活
鼠标移动
会发现鼠标弹指间运动到坐标(1,1)的职位,小编的微处理器是一九一六*1080的,最右下角的坐标正是(一九一七,1080)。
将move换成smooth_move,会发觉鼠标稳步地移动到钦点坐标
鼠标移动
复制如下代码,运营
#coding=utf-8import time import autopy#quick moveautopy.mouse.move(1,1) #smooth move#autopy.mouse.smooth_move(1370,120)
会发觉鼠标眨眼间间运动到坐标的岗位,小编的电脑是1919*1080的,最右下角的坐标正是(一九二〇,1080)。
将move换成smooth_move,会发现鼠标渐渐地活动到钦命坐标
法定文档的解释:
autopy.mouse.move(x: float, y: float)
Moves the mouse to the given coordinate.
Exceptions:
ValueError is thrown if the point is out of index.
autopy.mouse.smooth_move(x: float, y: float)
Smoothly moves the mouse to the given coordinate in a straight line.
Exceptions:
ValueError is thrown if the point is out of index.
坐标超越分辨率会报分外
1.扫雷游戏
鼠标点击
运转代码,发现脚下岗位爆发了点击操作
鼠标点击
运作代码,发现近年来地方发生了点击操作
#coding=utf-8import autopyautopy.mouse.click() # 单击
演示
本人是win10,没有暗中认可的扫雷,所以去扫雷网下载
键盘操作
普遍的键值码和键的呼应:
此处须要win32api包
调用win32api的keybd_event方法,用过要释放按键
能够看来,达成了切换窗口的操作,也便是大家按alt+tab,然后回车进入
键盘操作
上边时某些周边的键值码和键的照应:
字母和数字键 数字小键盘的键 效用键 其余键
键 键码 键 键码 键 键码 键 键码
A 65 0 96 F1112 Backspace 8
B 66 1 97 F2113 Tab 9
C 67 2 98 F3114 Clear 12
D 68 3 99 F4115 Enter 13
E 69 4 100 F5 116 Shift 16
F 70 5 101 F6 117 Control 17
G 71 6 102 F7 118 Alt 18
H 72 7 103 F8 119 Caps Lock 20
I 73 8 104 F9 120 Esc 27
J 74 9 105 F10121 Spacebar 32
K 75 * 106 F11 122 Page Up 33
L 76 + 107 F12 123 Page Down 34
M 77 Enter 108 End 35
N 78 – 109 Home 36
O 79 . 110 Left Arrow 37
P 80 / 111 Up Arrow38
Q 81 RightArrow 39
R 82 DownArrow 40
S 83 Insert 45
T 84 Delete 46
U 85 Help 47
V 86 NumLock 144
W87
X88
美高梅开户网址,Y89
Z90
048
149
250
351
4 52
553
654
755
856
9 57
复制代码,运维,这里供给win32api包
调用win32api的keybd_event方法,用过要释放按键
#coding=utf-8import timeimport win32api win32api.keybd_event(18,0,0,0) #alt键位码是18win32api.keybd_event(9,0,0,0) #tab键位码是9time.sleep(0.5)win32api.keybd_event(13,0,0,0) #enter键位码是13 win32api.keybd_event(18,0,win32con.KEYEVENTF_KEYUP,0) #释放按键win32api.keybd_event(9,0,win32con.KEYEVENTF_KEYUP,0)win32api.keybd_event(13,0,win32con.KEYEVENTF_KEYUP,0)time.sleep(2)
能够见到,达成了切换窗口的操作,也正是我们按alt+tab,然后回车进入
发端营造游戏脚本
此间以问道手游为例(回合制手游类似)
亟需夜神模拟器,并在模拟器上设置问道
笔者试过蓝叠和MuMu模拟器,作者用autopy移动鼠标到模拟器时鼠标就熄灭了,不可能做到后续的活动操作,后来百度了
说有的模拟器不受win窗口的决定。不管那么多,我们先用夜神模拟器吧!
跻身娱乐,打开”活动”
我们以”比赛场”活动举例表达
此处大家要用到截图工具,作者用的是PicPick
个人用户免费,笔者重点用它来衡量坐标
笔录下竞赛场前往的坐标(1358,504)
记录下比赛场按钮的坐标(1332,650)
成立回合制脚本首先得要熟识义务流程
接下来点击比赛场,走完那么些义务流程,依次记录按钮的坐标
比赛场职务一天能够做7遍,大家对手续循环六回
战斗岁月大家须要协调来计时,分歧门派,土豪只怕平民玩家时间都不雷同
笔者是公民玩家,大致耗费时间60s,点击过挑衅让代码延迟60s再继续执行
始于营造外挂:
此地以问道手游为例
内需夜神模拟器,并在模拟器上安装问道
本人试过蓝叠和MuMu模拟器,笔者用autopy移动鼠标到模拟器时鼠标就没有了,不能够形成后续的机动操作,后来百度了
说有的模拟器不受win窗口的支配。不管那么多,我们先用夜神模拟器吧!
跻身娱乐,打开“活动”
咱俩以“竞赛场”活动举例表明
此地大家要用到截图工具,小编用的是PicPick
个人用户免费,作者首要用它来衡量坐标
笔录下比赛场前往的坐标
笔录下竞赛场按钮的坐标
制作回合制脚本首先得要熟谙任务流程
接下来点击比赛场,走完那几个任务流程,依次记录按钮的坐标
竞赛场职责一天能够做九遍,大家对手续循环4次
战斗岁月大家须求协调来计时,区别门派,土豪只怕平民玩家时间都差异
本人是百姓玩家,大致耗费时间60s,点击过挑衅让代码延迟60s再继续执行
复制代码,运转
#coding=utf-8import autopyimport timeimport win32apiimport win32con#竞技场win32api.keybd_event(18,0,0,0) #alt键位码是18win32api.keybd_event(9,0,0,0) #tab键位码是9time.sleep(0.5)win32api.keybd_event(13,0,0,0) #enter键位码是13 win32api.keybd_event(18,0,win32con.KEYEVENTF_KEYUP,0) #释放按键win32api.keybd_event(9,0,win32con.KEYEVENTF_KEYUP,0)win32api.keybd_event(13,0,win32con.KEYEVENTF_KEYUP,0)time.sleep(2) def mousemove_click: autopy.mouse.smooth_move autopy.mouse.click() mousemove_click(771, 203) # 活动的坐标 mousemove_click(1358,504) # 竞技场"前往"的坐标 time.sleep(20)#从天墉城城中心/其他地图走到竞技使者花费20s mousemove_click(1334, 650) # 竞技使者对话框中的竞技场的坐标 #挑战完毕会出现对话窗口for i in range(1,6,1): mousemove_click(664,706) #挑战试炼童子 mousemove_click(1082,578) #确认 mousemove_click(1530, 794) # 战斗自动 time.sleep(60)#挑战试炼童子预计60s
进程大概是每分钟11个,假如再慢的话从速度上大可能率先种方案会是相比较好的挑三拣四。
代码
功效如下:
下一集将介绍怎样完结队长形式刷道(自动组队,自动跑环接职务)
Pywinauto
先看看简介吧。pywinauto is a set of python modules to automate the
Microsoft Windows GUI. At it’s simplest it allows you to send mouse
and keyboard actions to windows dialogs and controls.
哦,是个Windows的自动化操作工具。
支持文书档案
要点五个按钮,首先要明了怎么找这几个按钮吧?在那边她的三个示范是有关记事本的,学习了弹指间,大约是透过窗口类名和标题来找的部件,说到此处就要用到Spy++(大概Spy++Lite)
百度网盘的言传身教
如同此拖一下就找出来了。
哈哈哈,初次用这些Pywinauto感觉还挺厉害的,然则笔者把他用到网盘上的时候…笔者就蒙蔽了-
-,这些离线下载的按钮在Spy++Lite中找不到,换了别样种种找元件的工具都查不出去,Pywinauto输出这些主窗口包蕴的构件也不管用。网上查了一下那是为什么,只怕是那个按钮他丫的就不是个正式的按钮!那该怎么做呢?
2.python 3
关于按钮的煎熬
这一段着实是瞎折腾,最初的想法并不曾水到渠成,最后选项了鼠标模拟,发上来给大家参考参考吧,大家有指正大概好的创新措施快来告诉自个儿哟~(就此大约那段能够跳过了?(划掉))
网上看到别的一个方案——窗口收到了什么样新闻,就模仿如何音信;收到了鼠标按下按键那些音信,就仿照那一个音讯。
于是乎又在Spy++里面瞎折腾,先开辟百度云主窗口,然后在Spy++里面著录它接受的消息,找到了这样一条
找到了按下离线下载之后的窗口的句柄
正是那么些消息用到了我们必要的句柄
离线下载那一个按钮的功效正是激活这几个新建的窗口,那咱们得到这么些句柄(也正是窗口的地位)来激活,不就不要管这么些按钮了呢?可是那些句柄是什么产生的吗?它到底是在按下按钮的即刻发出的,依旧在按下以前就存的有啊?在Spy++中从按下鼠标之后收获到的消息并不曾回来这一个句柄,呵呵,小编就天真地暂定它是事先就存的有吧。尽管你存的有,这又该怎么找呢?嘿嘿,作者想开了CheatEngine来寻找。
新建离线下载窗口的句柄
哇,那不是有规律嘛!第④位每回+1!
可是当下我又被打脸了…开个别的窗口再来开它,嗯……(手动再见)
好吧…作者低头了…就依据按键脚本来写吧…
本身的本子是 python 3.6.1
后台鼠标音信
好了,现在初叶试着写按键脚本…大约想法正是获得主窗口的句柄,用坐标的不二法门取得按钮的地方,然后模拟点击。这里可能用按键天使的抓抓会相比较方便。
拖动到窗口内“离线下载”按钮上
在按键天使中测试 主窗口句柄为133248
在那边需求留意按键精灵抓出来的句柄是10进制的。
测试成功啦,看来能够用那一个措施,这就一通写出来吧。
出殡文书
那边难点正是离线下载的地址填不进去!它就好像此默默地望着您,一动不动!
按键天使不行,试试Pywinauto?
3.python的第①方库
移植到Python
……别试了,Pywinauto发送文书也不行。它们用的应有都是WIN
API,所以应当换个思路了。在这里自个儿的想法是模拟人操作,把地方Ctrl+C一下,然后到文本框Ctrl+V一下。在此地即使Pywinauto有Ctrl+V,但却从不Ctrl+C(卧槽那是如何操作啊啊啊)依然用win
api吧。注意那个SetClipboardData涉及了一句,
必须用NULL甘休字符串。使用此格式为ANSI文本。
因而大家在地点前面加上一句
.encode('ansi')
不然粘贴过去正是那样的
除此以外文本框还有贰个坑,像上边那样查询链接战败以来地址就留在那里了,所以应当是Ctrl+A
Ctrl+V。而文本框发送Ctrl+A
Ctrl+V有的时候会Ctrl莫名奇妙失效,多出去三个a,粘贴过去是amagnet,所以在那边几乎都遵照存在文字的情况处理,发送A
Ctrl+A Ctrl+V
下2个窗口。
中标升级!
固然如此能够依照偏移点击的办法解决,但还要笔者意识能够经过Tab Tab
Enter的主意成功下载,大概现在碰到坐标偏移量是浮动的时候能够尝尝那种格局?
逐一用鼠标点击钦定坐标的格局到了最终一个窗口了,关掉这几个窗口,正是本子的3个循环啦。
关掉这一个窗口
win32api,win32gui,win32con,Pillow,numpy,opencv
总结
一伊始自作者并不知道Pywinauto有后台鼠标音信,于是写了1个用winapi模拟点击的版本,也放上来吧。
from pywinauto import application
import win32api
import win32gui
import win32con
import win32ui
main_handle=win32ui.FindWindow('BaseGui','欢迎使用百度网盘').GetSafeHwnd()
client_pos=(516,118)
tmp = win32api.MAKELONG(client_pos[0], client_pos[1])
win32gui.SendMessage(main_handle, win32con.WM_ACTIVATE, win32con.WA_ACTIVE, 0)
win32api.SendMessage(main_handle, win32con.WM_LBUTTONDOWN, win32con.MK_LBUTTON, tmp)
win32api.SendMessage(main_handle, win32con.WM_LBUTTONUP, win32con.MK_LBUTTON, tmp)
此次实验依然有成都百货上千题材,包罗Python达成电影排行榜活动网盘下载(3)Selenium离线下载一致出现的欲速不达,所以最后代码中插手了wait_until;还有下载一定次数之后查询磁力链接没反应,重启客户端可消除;以及各样查询失利、离线下载错误……总之,应对错误的逻辑还有待创新,在此地只是不难的设定为add_task出现难点之后直接重启客户端,即查询不了下载音信就重启。还有任何情况并未处理,包含下载进程为0%,这种职分多了会唤起离线下载任务过多,供给手动清理,若是不合规能源较多,大概导致重启频仍,影响过程。代码的话可能要求据悉实际运作状态修改超时时间。由于速度过快平常简单查不到句柄啥的,就都用try
except括起来了,感觉非常不好看却很无奈,献丑啦:
import pywinauto
import time
import win32clipboard as w
import win32con
from pywinauto.timings import *
from pywinauto.application import Application
class baidudisk:
def boot(self):
path=r'C:\Users\Administrator\AppData\Roaming\Baidu\BaiduNetdisk\BaiduNetdisk.exe'
#Python3 中Application要加()
self.baiduapp=Application().start(path)
try:
#规定时间内等待程序启动
wait_until(10,0.25,self.getmainui,True)
except Exception as e:
print('Get Main Window ')
print(e)
def kill(self):
self.baiduapp.kill()
def download(self,url):
#剪切板函数要求数据类型为ANSI
self.url=url.encode('ansi')
try:
wait_until(1,0.25,self.click_newtask,True)
except Exception as e:
print('Download button ')
print(e)
try:
wait_until(1,0.25,self.query_newtask,True)
except Exception as e:
print('Query')
print(e)
try:
wait_until(4,0.25,self.add_newtask,True)
except Exception as e:
print('Add task')
print(e)
print('Rebooting...')
self.baiduapp.kill()
self.boot()
try:
wait_until(3,0.25,self.close_state,True)
except Exception as e:
print('State Window')
print(e)
def click_newtask(self):
try:
self.main_ui.click(coords=(516,118))
return (True)
except Exception as e:
print(e)
return (False)
def query_newtask(self):
try:
newtask_handle=pywinauto.findwindows.find_window(class_name="BaseGui",title= "新建离线下载任务窗口")
newtask_ui=pywinauto.controls.hwndwrapper.DialogWrapper(newtask_handle)
url_ui=newtask_ui.descendants()[0]
# url_ui.set_keyboard_focus()
w.OpenClipboard()
w.EmptyClipboard()
w.SetClipboardData(win32con.CF_TEXT, self.url)
w.CloseClipboard()
url_ui.send_keystrokes('a^a^v')
# print(url_ui.element_info)
# print(url_ui.get_properties())
#添加磁力链接后下载
newtask_ui.click(coords=(470,255))
return (True)
except Exception as e:
print(e)
return (False)
def add_newtask(self):
try:
download_handle=pywinauto.findwindows.find_window(class_name="BaseGui",title= '新建离线BT任务')
download_ui=pywinauto.controls.hwndwrapper.DialogWrapper(download_handle)
download_ui.click(coords=(400,470))
#可能出现离线下载错误时该窗口不会正常关闭的情况 所以使用try
try:
download_ui.close()
except:
pass
return (True)
except Exception as e:
print(e)
return (False)
def close_state(self):
try:
state_handle=pywinauto.findwindows.find_window(class_name="BaseGui",title= '离线下载任务列表')
state_ui=pywinauto.controls.hwndwrapper.DialogWrapper(state_handle)
state_ui.close()
return (True)
except Exception as e:
print(e)
return (False)
def getmainui(self):
try:
#返回窗口句柄
self.baidudisk_handle=pywinauto.findwindows.find_window(class_name='BaseGui',title='欢迎使用百度网盘')
#根据窗口句柄查询对话框
self.main_ui=pywinauto.controls.hwndwrapper.DialogWrapper(self.baidudisk_handle)
return (True)
except Exception as e:
print(e)
return (False)
if __name__=='__main__':
bdtest=baidudisk()
bdtest.boot()
#正常与违规的链接均进行测试
magnets=[
'magnet:?xt=urn:btih:583bed331c32889897f69b114191c44732bb7aa2',
'magnet:?xt=urn:btih:FD351CACF9692E1833388B3B5A568C6A115E4672&xl=546661540&dn=[%E6%A5%9A%E9%97%A8%E7%9A%84%E4%B8%96%E7%95%8C].rmvb',
'magnet:?xt=urn:btih:F77F5133B209D29126812CFAC9B0FE2508DC52A9&xl=584113510&dn=%E9%9C%B8%E7%8E%8B%E5%88%AB%E5%A7%AC.rmvb',
'magnet:?xt=urn:btih:E2A87A1922139C5C44965B77F5EC21F1442C97A4&xl=1073579448&dn=#_IBW118',
'magnet:?xt=urn:btih:CC2711AE1A5CCB8CB5FB3E6F900F404BD4792517&xl=1367609104&dn=%E9%98%BF%E7%94%98%E6%AD%A3%E4%BC%A0.[1024%E5%88%86%E8%BE%A8%E7%8E%87].rmvb'
]
for i in range(20):
bdtest.download(magnets[i%5])
有关什么批量取得磁力链接地址可参考往期名目繁多文章:
Python完成电影排行榜活动网盘下载(4)Cookies免登录+抓包下载
Python完成电影排名榜活动网盘下载(3)Selenium离线下载
Python达成电影排名榜活动网盘下载(2)Scrapy深刻“打包员”“快递员”
Python达成电影排名榜活动网盘下载(1)Scrapy爬虫框架
Python完毕电影排名榜活动网盘下载(0)简介
搜狐云音乐评论抓取实验(1)接口获取
可通过 pip install –upgrade SomePackage 来进展设置
注意:有个别版本是下载pywin32,然而部分要把pywin32晋升到最高并机关下载了pypiwin32,具体情状各个python版本恐怕都略有不一样
本身付出小编的第叁方库和本子仅供参考
② 、关键代码组成
1.找到游戏窗口与坐标
#扫雷游戏窗口
class_name = "TMain"
title_name = "Minesweeper Arbiter "
hwnd = win32gui.FindWindow(class_name, title_name)
#窗口坐标
left = 0
top = 0
right = 0
bottom = 0
if hwnd:
print("找到窗口")
left, top, right, bottom = win32gui.GetWindowRect(hwnd)
#win32gui.SetForegroundWindow(hwnd)
print("窗口坐标:")
print(str(left)+' '+str(right)+' '+str(top)+' '+str(bottom))
else:
print("未找到窗口")
2.锁定并抓取雷区图像
#锁定雷区坐标#去除周围功能按钮以及多余的界面#具体的像素值是通过QQ的截图来判断的
left += 15
top += 101
right -= 15
bottom -= 42
#抓取雷区图像
rect = (left, top, right, bottom)
img = ImageGrab.grab().crop(rect)
3.各图像的陆风X8GBA值
#数字1-8 周围雷数
#0 未被打开
#ed 被打开 空白
#hongqi 红旗
#boom 普通雷#boom_red 踩中的雷
rgba_ed = [(225, (192, 192, 192)), (31, (128, 128, 128))]
rgba_hongqi = [(54, (255, 255, 255)), (17, (255, 0, 0)), (109, (192, 192, 192)), (54, (128, 128, 128)), (22, (0, 0, 0))]
rgba_0 = [(54, (255, 255, 255)), (148, (192, 192, 192)), (54, (128, 128, 128))]
rgba_1 = [(185, (192, 192, 192)), (31, (128, 128, 128)), (40, (0, 0, 255))]
rgba_2 = [(160, (192, 192, 192)), (31, (128, 128, 128)), (65, (0, 128, 0))]
rgba_3 = [(62, (255, 0, 0)), (163, (192, 192, 192)), (31, (128, 128, 128))]
rgba_4 = [(169, (192, 192, 192)), (31, (128, 128, 128)), (56, (0, 0, 128))]
rgba_5 = [(70, (128, 0, 0)), (155, (192, 192, 192)), (31, (128, 128, 128))]
rgba_6 = [(153, (192, 192, 192)), (31, (128, 128, 128)), (72, (0, 128, 128))]
rgba_8 = [(149, (192, 192, 192)), (107, (128, 128, 128))]
rgba_boom = [(4, (255, 255, 255)), (144, (192, 192, 192)), (31, (128, 128, 128)), (77, (0, 0, 0))]
rgba_boom_red = [(4, (255, 255, 255)), (144, (255, 0, 0)), (31, (128, 128, 128)), (77, (0, 0, 0))]
4.扫描雷区图像保存至五个二维数组map
#扫描雷区图像
def showmap():
img = ImageGrab.grab().crop(rect)
for y in range(blocks_y):
for x in range(blocks_x):
this_image = img.crop((x * block_width, y * block_height, (x + 1) * block_width, (y + 1) * block_height))
if this_image.getcolors() == rgba_0:
map[y][x] = 0
elif this_image.getcolors() == rgba_1:
map[y][x] = 1
elif this_image.getcolors() == rgba_2:
map[y][x] = 2
elif this_image.getcolors() == rgba_3:
map[y][x] = 3
elif this_image.getcolors() == rgba_4:
map[y][x] = 4
elif this_image.getcolors() == rgba_5:
map[y][x] = 5
elif this_image.getcolors() == rgba_6:
map[y][x] = 6
elif this_image.getcolors() == rgba_8:
map[y][x] = 8
elif this_image.getcolors() == rgba_ed:
map[y][x] = -1
elif this_image.getcolors() == rgba_hongqi:
map[y][x] = -4
elif this_image.getcolors() == rgba_boom or this_image.getcolors() == rgba_boom_red:
global gameover
gameover = 1
break
#sys.exit(0)
else:
print("无法识别图像")
print("坐标")
print((y,x))
print("颜色")
print(this_image.getcolors())
sys.exit(0)
#print(map)
5.扫雷算法
那里笔者使用的最基础的算法
1.先是点出二个点
2.围观全数数字,如若周围空白+插旗==数字,则空手均有雷,右键点击空白插旗
3.扫描全部数字,如若周围插旗==数字,则空手均没有雷,左键点击空白
4.循环二 、3,尽管没有符合条件的,则随机点击3个白块
#插旗
def banner():
showmap()
for y in range(blocks_y):
for x in range(blocks_x):
if 1 <= map[y][x] and map[y][x] <= 5:
boom_number = map[y][x]
block_white = 0
block_qi = 0
for yy in range(y-1,y+2):
for xx in range(x-1,x+2):
if 0 <= yy and 0 <= xx and yy < blocks_y and xx < blocks_x:
if not (yy == y and xx == x):if map[yy][xx] == 0:
block_white += 1
elif map[yy][xx] == -4:
block_qi += 1if boom_number == block_white + block_qi:for yy in range(y - 1, y + 2):
for xx in range(x - 1, x + 2):
if 0 <= yy and 0 <= xx and yy < blocks_y and xx < blocks_x:
if not (yy == y and xx == x):
if map[yy][xx] == 0:
win32api.SetCursorPos([left+xx*block_width, top+yy*block_height])
win32api.mouse_event(win32con.MOUSEEVENTF_RIGHTDOWN, 0, 0, 0, 0)
win32api.mouse_event(win32con.MOUSEEVENTF_RIGHTUP, 0, 0, 0, 0)
showmap()
#点击白块
def dig():
showmap()
iscluck = 0
for y in range(blocks_y):
for x in range(blocks_x):
if 1 <= map[y][x] and map[y][x] <= 5:
boom_number = map[y][x]
block_white = 0
block_qi = 0
for yy in range(y - 1, y + 2):
for xx in range(x - 1, x + 2):
if 0 <= yy and 0 <= xx and yy < blocks_y and xx < blocks_x:
if not (yy == y and xx == x):
if map[yy][xx] == 0:
block_white += 1
elif map[yy][xx] == -4:
block_qi += 1if boom_number == block_qi and block_white > 0:for yy in range(y - 1, y + 2):
for xx in range(x - 1, x + 2):
if 0 <= yy and 0 <= xx and yy < blocks_y and xx < blocks_x:
if not(yy == y and xx == x):
if map[yy][xx] == 0:
win32api.SetCursorPos([left + xx * block_width, top + yy * block_height])
win32api.mouse_event(win32con.MOUSEEVENTF_LEFTDOWN, 0, 0, 0, 0)
win32api.mouse_event(win32con.MOUSEEVENTF_LEFTUP, 0, 0, 0, 0)
iscluck = 1
if iscluck == 0:
luck()
#随机点击
def luck():
fl = 1
while(fl):
random_x = random.randint(0, blocks_x - 1)
random_y = random.randint(0, blocks_y - 1)
if(map[random_y][random_x] == 0):
win32api.SetCursorPos([left + random_x * block_width, top + random_y * block_height])
win32api.mouse_event(win32con.MOUSEEVENTF_LEFTDOWN, 0, 0, 0, 0)
win32api.mouse_event(win32con.MOUSEEVENTF_LEFTUP, 0, 0, 0, 0)
fl = 0
def gogo(): win32api.SetCursorPos([left, top]) win32api.mouse_event(win32con.MOUSEEVENTF_LEFTDOWN, 0, 0, 0, 0) win32api.mouse_event(win32con.MOUSEEVENTF_LEFTUP, 0, 0, 0, 0) showmap() global gameover while(1): if(gameover == 0): banner() banner() dig() else: gameover = 0 win32api.keybd_event(113, 0, 0, 0) win32api.SetCursorPos([left, top]) win32api.mouse_event(win32con.MOUSEEVENTF_LEFTDOWN, 0, 0, 0, 0) win32api.mouse_event(win32con.MOUSEEVENTF_LEFTUP, 0, 0, 0, 0) showmap()
本条算法在低级和高级中学级通过率都不错,可是在高档成功率惨不忍睹,重倘若尚未设想逻辑组合以及白块是雷的可能率难题,能够对那三个点展开革新,提升成功率
总结
以上正是那篇作品的全体内容了,希望本文的剧情对大家的就学只怕干活有所自然的参考学习价值,假诺有疑问我们能够留言调换,多谢我们对剧本之家的扶助。
你可能感兴趣的稿子:
- 基于Python达成的扫雷游戏实例代码
- Python自动扫雷完结格局
- 用python写扫雷游戏实例代码分享