1、前言

Python实现的qq连连看辅助, 仅用于学习, 请在练习模式下使用, 请不要拿去伤害玩家们...

很多人学习python,不知道从何学起。
很多人学习python,掌握了基本语法过后,不知道在哪里寻找案例上手。
很多已经做案例的人,却不知道如何去学习更加高深的知识。
那么针对这三类人,我给大家提供一个好的学习平台,免费领取视频教程,电子书籍,以及课程的源代码!
QQ群:1097524789

2、基本环境配置

版本:Python3.6

系统:Windows

3、相关模块:


1import PIL.ImageGrab
2import pyautogui
3import win32api
4import win32gui
5import win32con
6import time
7import random


1import PIL.ImageGrabimport pyautoguiimport win32apiimport win32guiimport win32conimport timeimport random

4、使用方法

开始游戏后运行就行了, 再次提示, 请在练习模式中使用, 否则可能会被其他玩家举报。

效果图

5、代码实现


1import PIL.ImageGrab
2import pyautogui
3import win32api
4import win32gui
5import win32con
6import time
7import random
8
9def color_hash(color):
10    value = ""
11    for i in range(5):
12        value += "%d,%d,%d," % (color[0], color[1], color[2])
13    return hash(value)
14
15
16def image_hash(img):
17    value = ""
18    for i in range(5):
19        c = img.getpixel((i * 3, i * 3))
20        value += "%d,%d,%d," % (c[0], c[1], c[2])
21    return hash(value)
22
23
24def game_area_image_to_matrix():
25    pos_to_image = {}
26
27    for row in range(ROW_NUM):
28        pos_to_image[row] = {}
29        for col in range(COL_NUM):
30            grid_left = col * grid_width
31            grid_top = row * grid_height
32            grid_right = grid_left + grid_width
33            grid_bottom = grid_top + grid_height
34
35            grid_image = game_area_image.crop((grid_left, grid_top, grid_right, grid_bottom))
36
37            pos_to_image[row][col] = grid_image
38
39    pos_to_type_id = {}
40    image_map = {}
41
42    empty_hash = color_hash((48, 76, 112))
43
44    for row in range(ROW_NUM):
45        pos_to_type_id[row] = {}
46        for col in range(COL_NUM):
47            this_image = pos_to_image[row][col]
48            this_image_hash = image_hash(this_image)
49            if this_image_hash == empty_hash:
50                pos_to_type_id[row][col] = 0
51                continue
52            image_map.setdefault(this_image_hash, len(image_map) + 1)
53            pos_to_type_id[row][col] = image_map.get(this_image_hash)
54
55    return pos_to_type_id
56
57
58def solve_matrix_one_step():
59    for key in map:
60        arr = map[key]
61        arr_len = len(arr)
62        for index1 in range(arr_len - 1):
63            point1 = arr[index1]
64            x1 = point1[0]
65            y1 = point1[1]
66            for index2 in range(index1 + 1, arr_len):
67                point2 = arr[index2]
68                x2 = point2[0]
69                y2 = point2[1]
70                if verifying_connectivity(x1, y1, x2, y2):
71                    arr.remove(point1)
72                    arr.remove(point2)
73                    matrix[y1][x1] = 0
74                    matrix[y2][x2] = 0
75                    if arr_len == 2:
76                        map.pop(key)
77                    return y1, x1, y2, x2
78
79
80def verifying_connectivity(x1, y1, x2, y2):
81    max_y1 = y1
82    while max_y1 + 1 < ROW_NUM and matrix[max_y1 + 1][x1] == 0:
83        max_y1 += 1
84    min_y1 = y1
85    while min_y1 - 1 >= 0 and matrix[min_y1 - 1][x1] == 0:
86        min_y1 -= 1
87
88    max_y2 = y2
89    while max_y2 + 1 < ROW_NUM and matrix[max_y2 + 1][x2] == 0:
90        max_y2 += 1
91    min_y2 = y2
92    while min_y2 - 1 >= 0 and matrix[min_y2 - 1][x2] == 0:
93        min_y2 -= 1
94
95    rg_min_y = max(min_y1, min_y2)
96    rg_max_y = min(max_y1, max_y2)
97    if rg_max_y >= rg_min_y:
98        for index_y in range(rg_min_y, rg_max_y + 1):
99            min_x = min(x1, x2)
100            max_x = max(x1, x2)
101            flag = True
102            for index_x in range(min_x + 1, max_x):
103                if matrix[index_y][index_x] != 0:
104                    flag = False
105                    break
106            if flag:
107                return True
108
109    max_x1 = x1
110    while max_x1 + 1 < COL_NUM and matrix[y1][max_x1 + 1] == 0:
111        max_x1 += 1
112    min_x1 = x1
113    while min_x1 - 1 >= 0 and matrix[y1][min_x1 - 1] == 0:
114        min_x1 -= 1
115
116    max_x2 = x2
117    while max_x2 + 1 < COL_NUM and matrix[y2][max_x2 + 1] == 0:
118        max_x2 += 1
119    min_x2 = x2
120    while min_x2 - 1 >= 0 and matrix[y2][min_x2 - 1] == 0:
121        min_x2 -= 1
122
123    rg_min_x = max(min_x1, min_x2)
124    rg_max_x = min(max_x1, max_x2)
125    if rg_max_x >= rg_min_x:
126        for index_x in range(rg_min_x, rg_max_x + 1):
127            min_y = min(y1, y2)
128            max_y = max(y1, y2)
129            flag = True
130            for index_y in range(min_y + 1, max_y):
131                if matrix[index_y][index_x] != 0:
132                    flag = False
133                    break
134            if flag:
135                return True
136
137    return False
138
139
140def execute_one_step(one_step):
141    from_row, from_col, to_row, to_col = one_step
142
143    from_x = game_area_left + (from_col + 0.5) * grid_width
144    from_y = game_area_top + (from_row + 0.5) * grid_height
145
146    to_x = game_area_left + (to_col + 0.5) * grid_width
147    to_y = game_area_top + (to_row + 0.5) * grid_height
148
149    pyautogui.moveTo(from_x, from_y)
150    pyautogui.click()
151
152    pyautogui.moveTo(to_x, to_y)
153    pyautogui.click()
154
155
156if __name__ == '__main__':
157
158    COL_NUM = 19
159    ROW_NUM = 11
160
161    screen_width = win32api.GetSystemMetrics(0)
162    screen_height = win32api.GetSystemMetrics(1)
163
164    hwnd = win32gui.FindWindow(win32con.NULL, 'QQ游戏 - 连连看角色版')
165    if hwnd == 0:
166        exit(-1)
167
168    win32gui.ShowWindow(hwnd, win32con.SW_RESTORE)
169    win32gui.SetForegroundWindow(hwnd)
170    window_left, window_top, window_right, window_bottom = win32gui.GetWindowRect(hwnd)
171    if min(window_left, window_top) < 0 or window_right > screen_width or window_bottom > screen_height:
172        exit(-1)
173    window_width = window_right - window_left
174    window_height = window_bottom - window_top
175
176    game_area_left = window_left + 14.0 / 800.0 * window_width
177    game_area_top = window_top + 181.0 / 600.0 * window_height
178    game_area_right = window_left + 603 / 800.0 * window_width
179    game_area_bottom = window_top + 566 / 600.0 * window_height
180
181    game_area_width = game_area_right - game_area_left
182    game_area_height = game_area_bottom - game_area_top
183    grid_width = game_area_width / COL_NUM
184    grid_height = game_area_height / ROW_NUM
185
186    game_area_image = PIL.ImageGrab.grab((game_area_left, game_area_top, game_area_right, game_area_bottom))
187
188    matrix = game_area_image_to_matrix()
189
190    map = {}
191
192    for y in range(ROW_NUM):
193        for x in range(COL_NUM):
194            grid_id = matrix[y][x]
195            if grid_id == 0:
196                continue
197            map.setdefault(grid_id, [])
198            arr = map[grid_id]
199            arr.append([x, y])
200
201    pyautogui.PAUSE = 0
202
203    while True:
204        one_step = solve_matrix_one_step()
205        if not one_step:
206            exit(0)
207        execute_one_step(one_step)
208        time.sleep(random.randint(0,0)/1000)

主要思路就是利用pywin32获取连连看游戏句柄, 获取游戏界面的图片, 对方块进行切割, 对每个方块取几个点的颜色进行比对, 均相同则认为是同一个方块,

然后模拟鼠标取消就行了, 代码的最后一行是每次点击的间隔。

用Python玩连连看是什么效果?的更多相关文章

  1. 程序员带你十天快速入门Python,玩转电脑软件开发(四)

    本系列文章立志于从一个已经习得一门编程语言的基础之上,全面介绍Python的相关开发过程和相关经验总结.本篇文章主要是基于上一篇的程序员带你十天快速入门Python,玩转电脑软件开发(三)的基础之上, ...

  2. 程序员带你十天快速入门Python,玩转电脑软件开发(二)

    关注今日头条-做全栈攻城狮,学代码也要读书,爱全栈,更爱生活.提供程序员技术及生活指导干货. 如果你真想学习,请评论学过的每篇文章,记录学习的痕迹. 请把所有教程文章中所提及的代码,最少敲写三遍,达到 ...

  3. 程序员带你十天快速入门Python,玩转电脑软件开发(一)

    关注今日头条-做全栈攻城狮,学代码也要读书,爱全栈,更爱生活.提供程序员技术及生活指导干货. 如果你真想学习,请评论学过的每篇文章,记录学习的痕迹. 请把所有教程文章中所提及的代码,最少敲写三遍,达到 ...

  4. 用Python玩转微信(一)

    欢迎大家访问我的个人网站<刘江的博客和教程>:www.liujiangblog.com 主要分享Python 及Django教程以及相关的博客 交流QQ群:453131687 今天偶然看见 ...

  5. 基于Python玩转人工智能最火框架 TensorFlow应用实践✍✍✍

    基于Python玩转人工智能最火框架  TensorFlow应用实践 随着 TensorFlow 在研究及产品中的应用日益广泛,很多开发者及研究者都希望能深入学习这一深度学习框架.而在昨天机器之心发起 ...

  6. 使用Python玩转WMI

    最近在网上搜索Python和WMI相关资料时,发现大部分文章都千篇一律,并且基本上只说了很基础的使用,并未深入说明如何使用WMI.本文打算更进一步,让我们使用Python玩转WMI. 1 什么是WMI ...

  7. 程序员带你十天快速入门Python,玩转电脑软件开发(三)

    声明:本次教程主要适用于已经习得一门编程语言的程序员.想要学习第二门语言.有梦想,立志做全栈攻城狮的你 . 如果是小白,也可以学习本教程.不过可能有些困难.如有问题在文章下方进行讨论.或者添加QQ群5 ...

  8. 基于Python玩转人工智能最火框架 TensorFlow应用实践

    慕K网-299元-基于Python玩转人工智能最火框架 TensorFlow应用实践 需要联系我,QQ:1844912514

  9. Python玩转Arduino——简单介绍

    关于Python语言的介绍安装请参考廖雪峰的Python教程 Python是一门解释型语言,虽然不能够像c语言一样编译上传到Arduino--什么你说MicroPython,我们再说Arduino呢- ...

随机推荐

  1. python 并发专题(五):离散事件仿真(事件循环生成器)

    出租车队运营仿真 创建几辆出租车,每辆车会拉几个乘客,然后回家.出租车首先驶离车库,四处徘徊,寻找乘客:拉到乘客后,行程开始:乘客下车后,继续四处徘徊. 程序解释 程序的输出示例: 创建 3 辆出租车 ...

  2. git分支管理的策略和冲突问题

    目录 备注: 知识点 关于分支中的冲突 分支管理的策略 分支策略 备注: 本文参考于廖雪峰老师的博客Git教程.依照其博客进行学习和记录,感谢其无私分享,也欢迎各位查看原文. 知识点 git log ...

  3. 基于ConcurrentHashMap的本地缓存

    基于ConcurrentHashMap的本地缓存 在系统中,有些数据,数据量小,但是访问十分频繁(例如国家标准行政区域数据),针对这种场景,需要将数据搞到应用的本地缓存中,以提升系统的访问效率,减少无 ...

  4. OSCP Learning Notes - Capstone(2)

    BTRSys v2.1 Walkthrough Preparation: Download the BTRSys virtual machine from the following website: ...

  5. ASP.NET CORE之中间件-自定义异常中间件

    参考资料:https://docs.microsoft.com/zh-cn/aspnet/core/fundamentals/middleware/?view=aspnetcore-3.1 1.一般A ...

  6. 洛谷 P5350 序列 珂朵莉树

    题目描述 分析 操作一.二.三为珂朵莉树的基本操作,操作四.五.六稍作转化即可 不会珂朵莉树请移步至这里 求和操作 把每一段区间分别取出,暴力相加 ll qh(ll l,ll r){ it2=Spli ...

  7. antd4 源码学习 :表单

    Evernote Export 首先.vue 的数据流是双向的,而 react 的数据流是单向的. 这意味着什么? 这意味着,vue 中,子组件可以用 emit 把数据更新传给父组件.而 react ...

  8. 【题解】cf1381c Mastermind

    序 (一道很考验思维质量的构造好题,而且需要注意的细节也很多.) 本题解主体使用的是简洁且小常数的\(O(nlogn)\)时间复杂度代码,并且包含其他方法的分析留给读者自行实现(其实是自己不会写或者写 ...

  9. .Net Core in Docker极简入门(下篇)

    Tips:本篇已加入系列文章阅读目录,可点击查看更多相关文章. 目录 前言 开始 Docker-Compose 代码修改 yml file up & down 镜像仓库 最后 前言 上一篇[. ...

  10. Linux重定向用法详解

    大家好,我是良许. 相信大家平时都会有需要复制粘贴数据的时候,如果是打开文件进行复制粘贴,就不可避免的需要较多的鼠标与键盘的操作,就会比较繁琐.那么有没有可以省掉这些繁琐操作的复制粘贴的方法呢? 答案 ...