威尼斯人线上娱乐

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

27 3月 , 2019  

前言

每一次玩回合制游戏的时候,顾虑太多的一般职责令人不胜其烦

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

前些天作者就用Python教大家做二个关于回合制游戏的脚本,该脚本只可以模拟鼠标键盘操作,并不能够改改游戏数量。

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

假定您须求一个不错的读书交换条件,那么你能够设想Python学习交换群:548377875;

万一您须求一份系统的读书资料,那么您能够考虑Python学习沟通群:548377875。

引入:

每一回玩回合制游戏的时候,优柔寡断的一般职分令人不胜其烦

玩问道的时候,我们愿意能够活动刷道,玩梦幻希望能半自动做师门、捉鬼等等

上回(Python达成电影排名榜活动网盘下载(4)Cookies免登录+抓包下载)说到,一段时间内能拓展多少次离线下载恐怕受限于验证码的输入。
在此有多个缓解方案,

前言

 

说明:

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

自个儿那边运用的python2.7

开发工具是PyCharm

  • 见招拆招 通过GUI优化验证码输入
    不怕有验证码,在用户一向输入验证码的情事下也是一点也不慢的。而且能够借此学习Python是如何做出GUI程序的,学起来也会是很有价值的,参考
    试验楼
    给Python3爬虫做3个界面
    以往有机遇大概会写点类似的试行案例。
  • 应用网盘客户端
    其一化解方案的长处就是尚未!验!证!码!缺点正是加上的速度视财富而定,假如违法财富较多,大概会导致频仍重启;再有实际那便是个按键脚本,接纳模拟鼠标、键盘等操作,感觉比较脑残…

电动扫雷一般分为两种,一种是读取内部存款和储蓄器数据,而另一种是通过分析图片获得数据,并经过模拟鼠标操作,那里本人用的是第三种艺术。

支出条件准备

Python2.7 + Windows

模块:autopy,可pip install autopy

早期知识准备:

首先下载autopy包,作者那边PyCharm能够一贯导入autopy包

要么用利用pip进行设置:pip install autopy

那篇文章记录了自身第二种方式的试行进度,最后测试了多少个磁力链接的增速,大约是这么的:

一 、准备干活

鼠标移动

威尼斯人线上娱乐 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.

坐标当先分辨率会报分外

威尼斯人线上娱乐 2

1.扫雷游戏

鼠标点击

运营代码,发现近日地点发生了点击操作

威尼斯人线上娱乐 3

 

鼠标点击

运转代码,发现近来岗位发生了点击操作

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

演示

python实战教程之自动扫雷,Python操纵网盘客户端批量离线下载小电影。自个儿是win10,没有暗中同意的扫雷,所以去扫雷网下载

键盘操作

周边的键值码和键的附和:

威尼斯人线上娱乐 4

 

此处须求win32api包

调用win32api的keybd_event方法,用过要自由按键

威尼斯人线上娱乐 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,然后回车进入

威尼斯人线上娱乐 6

始发创建游戏脚本

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

亟待夜神模拟器,并在模拟器上安装问道

本人试过蓝叠和MuMu模拟器,笔者用autopy移动鼠标到模拟器时鼠标就烟消云散了,无法到位后续的机动操作,后来百度了

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

威尼斯人线上娱乐 7

 

跻身娱乐,打开”活动”

威尼斯人线上娱乐 8

 

我们以”比赛场”活动举例表明

威尼斯人线上娱乐 9

 

此处大家要用到截图工具,作者用的是PicPick

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

威尼斯人线上娱乐 10

 

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

威尼斯人线上娱乐 11

 

笔录下竞赛场按钮的坐标(1332,650)

创设回合制脚本首先得要纯熟任务流程

接下来点击比赛场,走完那一个任务流程,依次记录按钮的坐标

比赛场职分一天能够做6遍,大家对手续循环伍遍

交火岁月大家须要协调来计时,区别门派,土豪或许平民玩家时间都不雷同

小编是黎民玩家,大致耗费时间60s,点击过挑战让代码延迟60s再继续执行

威尼斯人线上娱乐 12

 

开班制作外挂:

此间以问道手游为例

须求夜神模拟器,并在模拟器上设置问道

自己试过蓝叠和MuMu模拟器,作者用autopy移动鼠标到模拟器时鼠标就熄灭了,无法做到后续的自动操作,后来百度了

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

威尼斯人线上娱乐 13

进去游玩,打开“活动”

威尼斯人线上娱乐 14

我们以“竞赛场”活动举例说明

威尼斯人线上娱乐 15

这边我们要用到截图工具,笔者用的是PicPick

个人用户免费,笔者最首要用它来衡量坐标

威尼斯人线上娱乐 16

笔录下比赛场前往的坐标

威尼斯人线上娱乐 17

笔录下竞赛场按钮的坐标

创设回合制脚本首先得要熟习职责流程

然后点击比赛场,走完那几个职分流程,依次记录按钮的坐标

比赛场职分一天能够做5次,大家对手续循环7遍

应战岁月大家需求团结来计时,不一致门派,土豪大概平民玩家时间都不均等

自己是黎民玩家,大致耗费时间60s,点击过挑衅让代码延迟60s再继续执行

威尼斯人线上娱乐 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

进程差不离是每分钟11个,借使再慢的话从速度上只怕首先种方案会是相比较好的抉择。

威尼斯人线上娱乐 19

代码

威尼斯人线上娱乐 20

 

意义如下:

威尼斯人线上娱乐 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个按钮,首先要精通怎么找那些按钮吧?在此处她的二个演示是有关记事本的,学习了一晃,差不多是通过窗口类名标题来找的预制构件,说到那边就要用到Spy++(也许Spy++Lite)

威尼斯人线上娱乐 22

百度网盘的演示

就这么拖一下就找出来了。
哈哈,初次用这几个Pywinauto感觉还挺厉害的,但是小编把她用到网盘上的时候…笔者就蒙蔽了-
-,那么些离线下载的按钮在Spy++Lite中找不到,换了其余种种找元件的工具都查不出去,Pywinauto输出那个主窗口包括的部件也不论用。网上查了一晃那是干吗,恐怕是其一按钮他丫的就不是个正经的按钮!那该咋做吧?

2.python 3

至于按钮的煎熬

这一段着实是瞎折腾,最初的想法并没有大功告成,最后甄选了鼠标模拟,发上来给大家参考参考吧,大家有指正恐怕好的革新措施快来告诉本身啊~(所以大概那段能够跳过了?(划掉)
网上看到别的1个方案——窗口收到了什么样音信,就照本宣科怎么样新闻;收到了鼠标按下按键那几个音信,就仿照那一个音讯。
于是乎又在Spy++里面瞎折腾,先开辟百度云主窗口,然后在Spy++里面著录它接受的音信,找到了这般一条

威尼斯人线上娱乐 23

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

威尼斯人线上娱乐 24

就是以此新闻用到了大家供给的句柄

离线下载那些按钮的效用正是激活那么些新建的窗口,那我们获得这些句柄(也等于窗口的身份)来激活,不就无须管那一个按钮了吗?可是以此句柄是何许产生的啊?它到底是在按下按钮的一刹这爆发的,如故在按下在此之前就存的有呢?在Spy++中从按下鼠标之后收获到的消息并从未回去那几个句柄,呵呵,作者就天真地暂定它是后边就存的有吗。即使你存的有,这又该怎么找呢?嘿嘿,笔者想到了CheatEngine来寻找。

威尼斯人线上娱乐 25

新建离线下载窗口的句柄

哇,这不是有规律嘛!第⑤位每一次+1!
而是当下作者又被打脸了…开个其他窗口再来开它,嗯……(手动再见)

威尼斯人线上娱乐 26

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

本身的本子是 python 3.6.1

后台鼠标新闻

好了,现在起头试着写按键脚本…大概想法就是赢得主窗口的句柄,用坐标的法门获得按钮的职位,然后模拟点击。那里可能用按键精灵的抓抓会比较便宜。

威尼斯人线上娱乐 27

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

威尼斯人线上娱乐 28

在按键天使中测试 主窗口句柄为133248

在那边必要留意按键天使抓出来的句柄是10进制的。
测试成功啦,看来能够用那么些法子,那就一通写出来吧。

威尼斯人线上娱乐 29

发送文书

那里难点就是离线下载的地点填不进去!它就像是此默默地望着你,一动不动!

威尼斯人线上娱乐 30

按键精灵不行,试试Pywinauto?

3.python的第壹方库

移植到Python

……别试了,Pywinauto发送文书也卓殊。它们用的应当都以WIN
API,所以应当换个思路了。在此地作者的想法是模拟人操作,把地点Ctrl+C一下,然后到文本框Ctrl+V一下。在此处尽管Pywinauto有Ctrl+V,但却尚未Ctrl+C(卧槽那是哪些操作啊啊啊)依旧用win
api吧。注意那个SetClipboardData关联了一句,

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

故此大家在地方前边加上一句

.encode('ansi')

不然粘贴过去就是那样的

威尼斯人线上娱乐 31

别的文本框还有二个坑,像上面那样查询链接战败以来地址就留在那里了,所以应该是Ctrl+A
Ctrl+V。而文本框发送Ctrl+A
Ctrl+V有的时候会Ctrl莫名奇妙失效,多出来1个a,粘贴过去是amagnet,所以在那里大约都服从存在文字的情事处理,发送A
Ctrl+A Ctrl+V
下二个窗口。

威尼斯人线上娱乐 32

得逞升级!

虽说能够依据偏移点击的办法化解,但同时本身发现能够由此Tab Tab
Enter的点子完结下载,恐怕将来蒙受坐标偏移量是转变的时候能够品味这种措施?
依次用鼠标点击钦赐坐标的不二法门到了最后一个窗口了,关掉这些窗口,就是本子的二个循环啦。

威尼斯人线上娱乐 33

关掉这一个窗口

win32api,win32gui,win32con,Pillow,numpy,opencv

总结

一初步小编并不知道Pywinauto有后台鼠标新闻,于是写了3个用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版本大概都略有不一致

自家付出作者的第叁方库和本子仅供参考

威尼斯人线上娱乐 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.各图像的HighlanderGBA值

#数字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.首先点出3个点

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地图