python小游戏代码大全(python最简单游戏代码)
有哪些小游戏可以用python实现?
ant 蚂蚁2. bagels 百吉饼另外贪吃蛇,吃豆子都是可以的,直接代码就可以玩。
Python包括随您的安装一起分发的大量标准库。标准库有一个称为Turtle的模块,这是一种向普通人介绍python编程的流行方法。今天介绍的所有游戏都是使用Python及其Turtle模块实现的。
每个游戏都完全独立于其他游戏,不试一试 您永远都不知道最喜欢哪种游戏。
安装完之后我们可以使用"python -m freegames list"来查看所有的游戏
贪吃蛇
贪吃蛇 -经典街机游戏。使用箭头键导航并吃绿色食品。每次食用食物,蛇就会长出一段。避免自己进食或出界!
吃豆子
吃豆子 –经典街机游戏。使用箭头键导航并吃掉所有白色食物。提防漫游迷宫的红色幽灵。
Flappy
Flappy-bird启发游戏。单击屏幕拍打翅膀。当您飞越屏幕时,请当心黑乌鸦。
加农炮
大炮-射击运动。单击屏幕发射您的炮弹。炮弹在其路径中弹出蓝色气球。弹出所有气球,然后才能越过屏幕。
python小游戏2048,上班摸鱼必备(附源码)
话不多说,直接上菜
为了方便大家copy,我就不分段解释了
import turtle, random
# 定义一个类,用来画除了数字方块之外的图形
class BackGround(turtle.Turtle):
? ? def __init__(self):
? ? ? ? super().__init__()
? ? ? ? self.penup()
? ? ? ? self.ht()
? ? def draw_block(self):
? ? ? ? self.shape('bg.gif')? # 画出背景方块
? ? ? ? for i in allpos:
? ? ? ? ? ? self.goto(i)
? ? ? ? ? ? self.stamp()
? ? ? ? self.color('white', 'white')? # 画出其他背景
? ? ? ? self.goto(-215, 120)
? ? ? ? self.begin_fill()
? ? ? ? self.goto(215, 120)
? ? ? ? self.goto(215, 110)
? ? ? ? self.goto(-215, 110)
? ? ? ? self.end_fill()
? ? ? ? self.shape('title.gif')
? ? ? ? self.goto(-125, 210)
? ? ? ? self.stamp()
? ? ? ? self.shape('score.gif')
? ? ? ? self.goto(125, 245)
? ? ? ? self.stamp()
? ? ? ? self.shape('top_score.gif')
? ? ? ? self.goto(125, 170)
? ? ? ? self.stamp()
? ? # 游戏失败及达成2048的提示文字
? ? def judge(self):
? ? ? ? global flag_win, flag_win_lose_text
? ? ? ? self.color('blue')
? ? ? ? judge = 0? # 判断是否还有位置可以移动
? ? ? ? for i in block_dic.values():
? ? ? ? ? ? for j in block_dic.values():
? ? ? ? ? ? ? ? if i.num == 0 or i.num == j.num and i.distance(j) == 100:
? ? ? ? ? ? ? ? ? ? judge += 1
? ? ? ? if judge == 0:? # 无位置可移动,游戏失败
? ? ? ? ? ? self.write('? ? GAME OVER\n重新开始请按空格键', align='center', font=('黑体', 30, 'bold'))
? ? ? ? ? ? flag_win_lose_text = False
? ? ? ? if flag_win is True:? # 此条件让2048达成的判断只能进行一次
? ? ? ? ? ? for k in block_dic.values():
? ? ? ? ? ? ? ? if k.num == 2048:? # 游戏达成
? ? ? ? ? ? ? ? ? ? flag_win = False
? ? ? ? ? ? ? ? ? ? self.write('? ? 达成2048\n继续游戏请按回车键', align='center', font=('黑体', 30, 'bold'))
? ? ? ? ? ? ? ? ? ? flag_win_lose_text = False
? ? def win_lose_clear(self):
? ? ? ? global flag_win_lose_text
? ? ? ? self.clear()
? ? ? ? flag_win_lose_text = True
? ? def show_score(self):? # 分值的显示
? ? ? ? global score, top_score
? ? ? ? if score top_score:
? ? ? ? ? ? top_score = score
? ? ? ? ? ? with open('.\\score.txt', 'w') as f:
? ? ? ? ? ? ? ? f.write(f'{top_score}')
? ? ? ? self.color('white')
? ? ? ? self.goto(125, 210)
? ? ? ? self.clear()
? ? ? ? self.write(f'{score}', align='center', font=('Arial', 20, 'bold'))
? ? ? ? self.goto(125, 135)
? ? ? ? self.write(f'{top_score}', align='center', font=('Arial', 20, 'bold'))
# 数字方块类
class Block(turtle.Turtle):
? ? def __init__(self):
? ? ? ? super().__init__()
? ? ? ? self.ht()
? ? ? ? self.penup()
? ? ? ? self.num = 0
? ? def draw(self):
? ? ? ? self.clear()
? ? ? ? dic_draw = {2: '#eee6db', 4: '#efe0cd', 8: '#f5af7b',
? ? ? ? ? ? ? ? ? ? 16: '#fb9660', 32: '#f57d5a', 64: '#f95c3d',
? ? ? ? ? ? ? ? ? ? 128: '#eccc75', 256: '#eece61', 512: '#efc853',
? ? ? ? ? ? ? ? ? ? 1024: '#ebc53c', 2048: '#eec430', 4096: '#aeb879',
? ? ? ? ? ? ? ? ? ? 8192: '#aab767', 16384: '#a6b74f'}
? ? ? ? if self.num 0:? # 数字大于0,画出方块
? ? ? ? ? ? self.color(f'{dic_draw[self.num]}')? # 选择颜色
? ? ? ? ? ? self.begin_fill()
? ? ? ? ? ? self.goto(self.xcor()+48, self.ycor()+48)
? ? ? ? ? ? self.goto(self.xcor()-96, self.ycor())
? ? ? ? ? ? self.goto(self.xcor(), self.ycor()-96)
? ? ? ? ? ? self.goto(self.xcor()+96, self.ycor())
? ? ? ? ? ? self.goto(self.xcor(), self.ycor()+96)
? ? ? ? ? ? self.end_fill()
? ? ? ? ? ? self.goto(self.xcor()-48, self.ycor()-68)
? ? ? ? ? ? if self.num 4:? # 按照数字选择数字的颜色
? ? ? ? ? ? ? ? self.color('white')
? ? ? ? ? ? else:
? ? ? ? ? ? ? ? self.color('#6d6058')
? ? ? ? ? ? self.write(f'{self.num}', align='center', font=('Arial', 27, 'bold'))
? ? ? ? ? ? self.goto(self.xcor(), self.ycor()+20)
class Game():
? ? def init(self):
? ? ? ? back = BackGround()? # 实例画出游戏的背景
? ? ? ? back.draw_block()
? ? ? ? for i in allpos:? # 画出16个海龟对应16个数字块
? ? ? ? ? ? block = Block()
? ? ? ? ? ? block.goto(i)
? ? ? ? ? ? block_dic[i] = block
? ? ? ? game.grow()
? ? def restart(self):? # 重开游戏的方法
? ? ? ? global score, flag_win_lose_text
? ? ? ? score = 0
? ? ? ? for i in block_dic.values():
? ? ? ? ? ? i.num = 0
? ? ? ? ? ? i.clear()
? ? ? ? win_lose_text.clear()
? ? ? ? game.grow()
? ? ? ? flag_win_lose_text = True? # 此flag为游戏达成或失败出现提示语后的判断,要提示语被clear后才能继续move
? ? def grow(self):? # 随机出现一个2或4的数字块
? ? ? ? block_list = []
? ? ? ? for i in allpos:
? ? ? ? ? ? if block_dic[i].num == 0:
? ? ? ? ? ? ? ? block_list.append(block_dic[i])? # 挑出空白方块的海龟
? ? ? ? turtle_choice = random.choice(block_list)? # 随机选中其中一个海龟
? ? ? ? turtle_choice.num = random.choice([2, 2, 2, 2, 4])? # 赋属性num=2/4
? ? ? ? turtle_choice.draw()
? ? ? ? win_lose_text.judge()
? ? ? ? show_score_text.show_score()
? ? ? ? ms.update()
? ? def move_up(self):
? ? ? ? allpos1 = allpos[::4]? # 切片为四列
? ? ? ? allpos2 = allpos[1::4]
? ? ? ? allpos3 = allpos[2::4]
? ? ? ? allpos4 = allpos[3::4]
? ? ? ? self.move_move(allpos1, allpos2, allpos3, allpos4)
? ? def move_down(self):
? ? ? ? allpos1 = allpos[-4::-4]
? ? ? ? allpos2 = allpos[-3::-4]
? ? ? ? allpos3 = allpos[-2::-4]
? ? ? ? allpos4 = allpos[-1::-4]
? ? ? ? self.move_move(allpos1, allpos2, allpos3, allpos4)
? ? def move_left(self):
? ? ? ? allpos1 = allpos[:4]
? ? ? ? allpos2 = allpos[4:8]
? ? ? ? allpos3 = allpos[8:12]
? ? ? ? allpos4 = allpos[12:16]
? ? ? ? self.move_move(allpos1, allpos2, allpos3, allpos4)
? ? def move_right(self):
? ? ? ? allpos1 = allpos[-1:-5:-1]
? ? ? ? allpos2 = allpos[-5:-9:-1]
? ? ? ? allpos3 = allpos[-9:-13:-1]
? ? ? ? allpos4 = allpos[-13:-17:-1]
? ? ? ? self.move_move(allpos1, allpos2, allpos3, allpos4)
? ? def move_move(self, allpos1, allpos2, allpos3, allpos4):
? ? ? ? if flag_win_lose_text is True:
? ? ? ? ? ? count1 = self.move(allpos1)? # 四列或四行依次移动
? ? ? ? ? ? count2 = self.move(allpos2)
? ? ? ? ? ? count3 = self.move(allpos3)
? ? ? ? ? ? count4 = self.move(allpos4)
? ? ? ? ? ? if count1 or count2 or count3 or count4:? # 判断是否有方块移动,有才能继续出现新的数字块
? ? ? ? ? ? ? ? self.grow()
? ? def move(self, pos_list):
? ? ? ? num_list = []? # 为某一列或行的数字块海龟的坐标
? ? ? ? for i in pos_list:
? ? ? ? ? ? num_list.append(block_dic[i].num)? #? 把这些海龟的NUM形成list
? ? ? ? new_num_list, count = self.list_oper(num_list)? #? 只是list_oper的方法形成新的list
? ? ? ? for j in range(len(new_num_list)):? # 把新的list依次赋值给对应的海龟.num属性并调用draw()方法
? ? ? ? ? ? block_dic[pos_list[j]].num = new_num_list[j]
? ? ? ? ? ? block_dic[pos_list[j]].draw()
? ? ? ? return count
? ? def list_oper(self, num_list):? # num_list的操作,假设其为【2,0,2,2】
? ? ? ? global score
? ? ? ? count = True
? ? ? ? temp = []
? ? ? ? new_temp = []
? ? ? ? for j in num_list:
? ? ? ? ? ? if j != 0:
? ? ? ? ? ? ? ? temp.append(j)? # temp=[2,2,2]
? ? ? ? flag = True
? ? ? ? for k in range(len(temp)):
? ? ? ? ? ? if flag:
? ? ? ? ? ? ? ? if k len(temp)-1 and temp[k] == temp[k+1]:
? ? ? ? ? ? ? ? ? ? new_temp.append(temp[k]*2)
? ? ? ? ? ? ? ? ? ? flag = False
? ? ? ? ? ? ? ? ? ? score += temp[k]
? ? ? ? ? ? ? ? else:
? ? ? ? ? ? ? ? ? ? new_temp.append(temp[k])? # new_temp=[4,2]
? ? ? ? ? ? else:
? ? ? ? ? ? ? ? flag = True
? ? ? ? for m in range(len(num_list)-len(new_temp)):
? ? ? ? ? ? new_temp.append(0)? # new_temp=[4,2,0,0]
? ? ? ? if new_temp == num_list:
? ? ? ? ? ? count = False? # 此变量判断num_list没有变化,数字块无移动
? ? ? ? return(new_temp, count)
if __name__ == '__main__':
? ? ms = turtle.Screen()? # 主窗口的设置
? ? ms.setup(430, 630, 400, 50)
? ? ms.bgcolor('gray')
? ? ms.title('2048')
? ? ms.tracer(0)
? ? ms.register_shape('bg.gif')
? ? ms.register_shape('title.gif')
? ? ms.register_shape('score.gif')
? ? ms.register_shape('top_score.gif')
? ? block_dic = {}? # 放数字方块海龟的字典,位置坐标为key,对应海龟为value
? ? allpos = [(-150, 50), (-50, 50), (50, 50), (150, 50),
? ? ? ? ? ? ? (-150, -50), (-50, -50), (50, -50), (150, -50),
? ? ? ? ? ? ? (-150, -150), (-50, -150), (50, -150), (150, -150),
? ? ? ? ? ? ? (-150, -250), (-50, -250), (50, -250), (150, -250)]
? ? flag_win = True? # 达成2048的判断,让达成的文字仅出现一次
? ? flag_win_lose_text = True? # 用来判断失败或成功的提示文字是否有被清除,不清除不能继续移动方块
? ? score = 0
? ? with open('.\\score.txt', 'r') as f:
? ? ? ? top_score = int(f.read())? #? 读取score中的数据
? ? show_score_text = BackGround()
? ? win_lose_text = BackGround()
? ? game = Game()
? ? game.init()
? ? ms.listen()
? ? ms.onkey(game.move_up, 'Up')
? ? ms.onkey(game.move_down, 'Down')
? ? ms.onkey(game.move_left, 'Left')
? ? ms.onkey(game.move_right, 'Right')
? ? ms.onkey(win_lose_text.win_lose_clear, 'Return')
? ? ms.onkey(game.restart, 'space')
? ? ms.mainloop()
这是游戏界面:
欢迎挑战最高分。
要运行出来,必须本地要有这些文件:bg.gif,score.gif,title.gif,top_score.gif,score.txt
我把这些文件放在了群里,还有一些学习的资料,群号642109462,欢迎对python感兴趣的进群讨论。
支持作者的,可以关注和点赞。感谢你们!
6 个值得玩味的 Python 代码
先选取了 6 个自己认为值得玩味的 python代码,希望对正在学习 python 的你有所帮助。
1、类有两个方法,一个是 new,一个是 init,有什么区别,哪个会先执行呢?
运行结果如下:
再来看另一个例子
运行结果如下:
这里给出官方的解释: init 作用是类实例进行初始化,第一个参数为 self,代表对象本身,可以没有返回值。 new 则是返回一个新的类的实例,第一个参数是 cls 代表该类本身,必须有返回值。很明显,类先实例化才能产能对象,显然是 new 先执行,然后再 init ,实际上,只要 new 返回的是类本身的实例,它会自动调用 init 进行初始化。但是有例外,如果 new 返回的是其他类的实例,则它不会调用当前类的 init 。下面我们分别输出下对象 a 和对象 b 的类型:
可以看出,a 是 test 类的一个对象,而 b 就是 object 的对象。
2、map 函数返回的对象
map()函数第一个参数是 fun,第二个参数是一般是 list,第三个参数可以写 list,也可以不写,作用就是对列表中 list 的每个元素顺序调用函数 fun 。
有没有发现,第二次输出 b 中的元素时,发现变成空了。原因是 map() 函数返回的是一个迭代器,并用对返回结果使用了 yield,这样做的目的在于节省内存。 举个例子:
执行结果为:
这里如果不用 yield,那么在列表中的元素非常大时,将会全部装入内存,这是非常浪费内存的,同时也会降低效率。
3、正则表达式中 compile 是否多此一举?
比如现在有个需求,对于文本 中国 ,用正则匹配出标签里面的“中国”,其中 class 的类名是不确定的。有两种方法,代码如下:
这里为什么要用 compile 多写两行代码呢? 原因是 compile 将正则表达式编译成一个对象,加快速度,并重复使用。
4、[[1,2],[3,4],[5,6]]一行代码展开该列表,得出[1,2,3,4,5,6]
5、一行代码将字符串 "-" 插入到 "abcdefg"中每个字符的中间
这里也建议多使用 os.path.join() 来拼接操作系统的文件路径。
6、zip 函数
zip() 函数在运算时,会以一个或多个序列(可迭代对象)做为参数,返回一个元组的列表。同时将这些序列中并排的元素配对。zip() 参数可以接受任何类型的序列,同时也可以有两个以上的参数;当传入参数的长度不同时,zip 能自动以最短序列长度为准进行截取,获得元组。
100行Python代码,轻松完成贪吃蛇小游戏?
你是想让我们向你提问题?你这个放错地方了,应该发布到自己的博客或论坛上面才对
求个Python小游戏
浅浅的笑着:“我会带着你的孩子,
顚节进入
Python程序开发之简单小程序实例 (11)小 游戏 -跳动的小球 一、项目功能 用户控制挡板来阻挡跳动的小球。 二、项目分析 根据项目功能自定义两个类,一个用于控制小球在窗体中的运动,一个用于接收用户按下左右键时,挡板在窗体中的运动。在控制小球的类中,我们还需要考虑当小球下降时,碰到挡板时的位置判断。 三、程序源代码 源码部分截图: 源码: #!/usr/bin/python3.6 # -*- coding: GBK -*- #导入相应模块 from tkinter import * import random import time #自定义小球的类 Ball class Ball: # 初始化 def __init__(self,canvas,paddle,color): #传递画布值 self.canvas=canvas #传递挡板值 self.paddle=paddle #画圆并且保存其ID self.id=canvas.create_oval(10,10,25,25,fill=color) self.canvas.move(self.id,245,100) #小球的水平位置起始列表 start=[-3,-2,-1,1,2,3] #随机化位置列表 random.shuffle(start) self.x=start[0] self.y=-2 self.canvas_heigh=self.canvas.winfo_height()#获取窗口高度并保存 self.canvas_width=self.canvas.winfo_width() #根据参数值绘制小球 def draw(self): self.canvas.move(self.id,self.x,self.y) pos=self.canvas.coords(self.id)#返回相应ID代表的图形的当前坐标(左上角和右上角坐标) #使得小球不会超出窗口 pad=self.canvas.coords(self.paddle.id)#获取小球挡板的坐标 if pos[1]=self.canvas_heigh or(pos[3]=pad[1] and pos[2]=pad[0] and pos[2]