前言

每便玩回合制游戏的时候,心神不定的平时任务令人不胜其烦

玩问道的时候,大家盼望能够自行刷道,玩梦幻希望能自动做师门、捉鬼等等

后天小编就用Python教大家做2个有关回合制游戏的台本,该脚本只好模拟鼠标键盘操作,并不可能修改游戏数量。

作者:`Rest探路者`
源自:`

借使你须求三个好好的上学沟通条件,那么您能够考虑Python学习交换群:548377875;

假定您供给一份系统的就学资料,那么你能够设想Python学习交流群:548377875。

引入:

历次玩回合制游戏的时候,顾后瞻前的平常职分让人不胜其烦

玩问道的时候,大家期望能够自行刷道,玩梦幻希望能半自动做师门、捉鬼等等

上回(Python实现电影排名榜活动网盘下载(4)库克ies免登录+抓包下载)说到,一段时间内能进行多少次离线下载可能受限于验证码的输入。
在此有七个缓解方案,

前言

 

说明:

该外挂只好模拟鼠标键盘操作,并不可能修改游戏数量

自己这里运用的python2.7

开发工具是PyCharm

  • 见招拆招 通过GUI优化验证码输入
    不畏有验证码,在用户直接输入验证码的动静下也是快捷的。而且可以借此读书Python是怎么样做出GUI程序的,学起来也会是很有价值的,参考
    实验楼
    给Python3爬虫做3个界面
    未来有时机可能会写点类似的实验案例。
  • 采取网盘客户端
    以此消除方案的优点就是绝非!验!证!码!缺点正是增加的速度视资源而定,假若违规财富较多,也许会招致频仍重启;再有实在那就是个按键脚本,选取模拟鼠标、键盘等操作,感觉对比脑残…

电动扫雷一般分为二种,一种是读取内部存款和储蓄器数据,而另一种是透过分析图片获得多少,并因此模拟鼠标操作,那里笔者用的是第①种方法。

开发条件准备

Python2.7 + Windows

模块:autopy,可pip install autopy

初期知识准备:

第叁下载autopy包,小编那边PyCharm能够平素导入autopy包

抑或用利用pip进行设置:pip install autopy

那篇作品记录了自身第二种办法的实验进程,最终测试了多少个磁力链接的增速,大概是那般的:

① 、准备干活

鼠标移动

金沙注册送58 1

 

会发觉鼠标眨眼间间移动到坐标(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)

会发觉鼠标须臾间运动到坐标的岗位,作者的微处理器是壹玖壹玖*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.

坐标超过分辨率会报很是

金沙注册送58 2

python实战教程之自动扫雷,Python操纵网盘客户端批量离线下载小电影。1.扫雷游戏

鼠标点击

运转代码,发现脚下岗位产生了点击操作

金沙注册送58 3

 

鼠标点击

运作代码,发现脚下职分发生了点击操作

#coding=utf-8import autopyautopy.mouse.click() # 单击

演示

自身是win10,没有私下认可的扫雷,所以去扫雷网下载

键盘操作

科学普及的键值码和键的呼应:

金沙注册送58 4

 

那里需求win32api包

调用win32api的keybd_event方法,用过要释放按键

金沙注册送58 5

 

能够见见,完毕了切换窗口的操作,相当于大家按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,然后回车进入

金沙注册送58 6

起来制作游戏脚本

那边以问道手游为例(回合制手游类似)

亟待夜神模拟器,并在模拟器上设置问道

本身试过蓝叠和MuMu模拟器,作者用autopy移动鼠标到模拟器时鼠标就流失了,不能够形成后续的机关操作,后来百度了

说有个别模拟器不受win窗口的主宰。不管那么多,我们先用夜神模拟器吧!

金沙注册送58 7

 

进入游戏,打开”活动”

金沙注册送58 8

 

大家以”竞赛场”活动举例表达

金沙注册送58 9

 

那里大家要用到截图工具,作者用的是PicPick

个人用户免费,小编根本用它来衡量坐标

金沙注册送58 10

 

记录下比赛场前往的坐标(1358,504)

金沙注册送58 11

 

金沙注册送58 ,笔录下竞赛场按钮的坐标(1332,650)

创建回合制脚本首先得要熟习义务流程

下一场点击竞赛场,走完那些任务流程,依次记录按钮的坐标

竞赛场职责一天能够做八次,咱们对手续循环6次

应战岁月大家要求自个儿来计时,分化门派,土豪只怕平民玩家时间都不一致等

本身是百姓玩家,差不离耗费时间60s,点击过挑衅让代码延迟60s再继续执行

金沙注册送58 12

 

起来创立外挂:

这里以问道手游为例

急需夜神模拟器,并在模拟器上安装问道

自身试过蓝叠和MuMu模拟器,作者用autopy移动鼠标到模拟器时鼠标就消失了,不能够实现后续的自行操作,后来百度了

说有的模拟器不受win窗口的决定。不管那么多,大家先用夜神模拟器吧!

金沙注册送58 13

进去游玩,打开“活动”

金沙注册送58 14

大家以“竞赛场”活动举例表明

金沙注册送58 15

此处大家要用到截图工具,小编用的是PicPick

个人用户免费,笔者重点用它来衡量坐标

金沙注册送58 16

笔录下比赛场前往的坐标

金沙注册送58 17

笔录下竞赛场按钮的坐标

创制回合制脚本首先得要熟谙职务流程

下一场点击比赛场,走完这一个职责流程,依次记录按钮的坐标

比赛场职分一天能够做七回,大家敌手续循环八次

应战岁月咱们须要自身来计时,差异门派,土豪只怕平民玩家时间都不相同等

本人是人民玩家,差不离耗费时间60s,点击过挑衅让代码延迟60s再继续执行

金沙注册送58 18

复制代码,运行

#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

进程大概是每分钟10个,假设再慢的话从速度上恐怕率先种方案会是相比较好的选料。

金沙注册送58 19

代码

金沙注册送58 20

 

效益如下:

金沙注册送58 21

下一集将介绍如何完成队长形式刷道(自动组成代表队,自动跑环接任务)

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的自动化操作工具。
扶持文书档案
要点1个按钮,首先要了然怎么找这些按钮吧?在此间他的3个示范是关于记事本的,学习了一下,差不离是因此窗口类名标题来找的构件,说到此处即将用到Spy++(也许Spy++Lite)

金沙注册送58 22

百度网盘的言传身教

就那样拖一下就找出来了。
哈哈哈,初次用这几个Pywinauto感觉还挺厉害的,可是小编把他用到网盘上的时候…小编就蒙蔽了-
-,那个离线下载的按钮在Spy++Lite中找不到,换了别样各类找元件的工具都查不出来,Pywinauto输出这几个主窗口包罗的预制构件也随便用。网上查了一下那是干什么,恐怕是这些按钮他丫的就不是个正式的按钮!那该如何做吧?

2.python 3

至于按钮的折腾

这一段着实是瞎折腾,最初的想法并没有得逞,最后甄选了鼠标模拟,发上来给我们参考参考吧,大家有指正或许好的创新措施快来告诉自个儿啊~(故而差不多那段能够跳过了?(划掉)
网上看到别的三个方案——窗口收到了什么样音讯,就照猫画虎怎么着音信;收到了鼠标按下按键这一个信息,就仿照那几个新闻。
于是又在Spy++里面瞎折腾,先开辟百度云主窗口,然后在Spy++里面著录它接受的音讯,找到了这样一条

金沙注册送58 23

找到了按下离线下载之后的窗口的句柄

金沙注册送58 24

正是其一音讯用到了大家要求的句柄

离线下载那些按钮的法力正是激活这几个新建的窗口,那大家获得那几个句柄(约等于窗口的地位)来激活,不就毫无管那一个按钮了呢?但是那几个句柄是怎么着发生的呢?它终究是在按下按钮的眨眼之间间发出的,依然在按下在此之前就存的有啊?在Spy++中从按下鼠标之后收获到的新闻并不曾回来这一个句柄,呵呵,作者就天真地暂定它是事先就存的有吧。固然你存的有,那又该怎么找呢?嘿嘿,小编想开了CheatEngine来搜寻。

金沙注册送58 25

新建离线下载窗口的句柄

哇,那不是有规律嘛!第5位每一遍+1!
可是当下作者又被打脸了…开个别的窗口再来开它,嗯……(手动再见)

金沙注册送58 26

好吧…小编低头了…就依据按键脚本来写吧…

本身的版本是 python 3.6.1

后台鼠标新闻

好了,未来开首试着写按键脚本…大概想法便是取得主窗口的句柄,用坐标的办法取得按钮的职分,然后模拟点击。那里或者用按键天使的抓抓会比较方便。

金沙注册送58 27

拖动到窗口内“离线下载”按钮上

金沙注册送58 28

在按键精灵中测试 主窗口句柄为133248

在此间需求留意按键天使抓出来的句柄是10进制的。
测试成功啦,看来能够用这几个措施,那就一通写出来啊。

金沙注册送58 29

出殡文书

此地难题便是离线下载的地方填不进去!它就那样默默地望着您,寸步不移!

金沙注册送58 30

按键天使不行,试试Pywinauto?

3.python的第一方库

移植到Python

……别试了,Pywinauto发送文书也要命。它们用的相应都以WIN
API,所以应该换个思路了。在此间小编的想法是模拟人操作,把地方Ctrl+C一下,然后到文本框Ctrl+V一下。在那边固然Pywinauto有Ctrl+V,但却尚无Ctrl+C(卧槽那是怎么操作啊啊啊)照旧用win
api吧。注意那些SetClipboardData事关了一句,

务必用NULL甘休字符串。使用此格式为ANSI文本。

据此大家在地方前面加上一句

.encode('ansi')

要不然粘贴过去正是如此的

金沙注册送58 31

此外文本框还有1个坑,像上面那样查询链接战败以来地址就留在那里了,所以应当是Ctrl+A
Ctrl+V。而文本框发送Ctrl+A
Ctrl+V有的时候会Ctrl莫名奇妙失效,多出来1个a,粘贴过去是amagnet,所以在此间几乎都遵从存在文字的意况处理,发送A
Ctrl+A Ctrl+V
下1个窗口。

金沙注册送58 32

成功升级!

即使如此可以遵照偏移点击的不二法门解决,但还要作者意识能够透过Tab Tab
Enter的方法成就下载,或然以往碰到坐标偏移量是变化的时候能够品尝这种办法?
依次用鼠标点击钦定坐标的措施到了最后3个窗口了,关掉那一个窗口,就是本子的3个循环啦。

金沙注册送58 33

关闭这几个窗口

win32api,win32gui,win32con,Pillow,numpy,opencv

总结

一开首自笔者并不知道Pywinauto有后台鼠标新闻,于是写了三个用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版本只怕都略有区别

本身付出笔者的第贰方库和版本仅供参考

金沙注册送58 34 

贰 、关键代码组成

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.各图像的RubiconGBA值

#数字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,假若没有符合条件的,则随机点击一个白块

#插旗
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写扫雷游戏实例代码分享

相关文章

网站地图xml地图