2024年最新python写扫雷小游戏(pygame)_pygame 扫雷,大厂面试经验

如果你也是看准了Python,想自学Python,在这里为大家准备了丰厚的免费学习大礼包,带大家一起学习,给大家剖析Python兼职、就业行情前景的这些事儿。

一、Python所有方向的学习路线

Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

二、学习软件

工欲善其必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。

三、全套PDF电子书

书籍的好处就在于权威和体系健全,刚开始学习的时候你可以只看视频或者听某个人讲课,但等你学完之后,你觉得你掌握了,这时候建议还是得去看一下书籍,看权威技术书籍也是每个程序员必经之路。

四、入门学习视频

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。

四、实战案例

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

五、面试资料

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

成为一个Python程序员专家或许需要花费数年时间,但是打下坚实的基础只要几周就可以,如果你按照我提供的学习路线以及资料有意识地去实践,你就有很大可能成功!
最后祝你好运!!!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

            zhanghao_s=open('用户信息/zhanghao.txt','r')
            for each_line in zhanghao_s:
                (zhanghao_, huiche_) = each_line.split('\n')
            zhanghao_list.append(zhanghao_)
            zhanghao_s.close()
            choice = DengLu(zhanghao_list)
        elif choice=="取消注册":
            continue
    if choice == 2:
        choice = g.indexbox('开始/继续:', '请选择:', choices=['重新开始','继续游戏'])
        if choice==0:
            choose.main(zhanghao)
        elif choice==1:
            list3 = []
            N = open('用户信息/N_s.txt','r')
            for each_line in N:
                (mima_, huiche_) = each_line.split('\n')
                list3.append(mima_)
            N.close()
            n=int(list3[zhanghao])

            list4=[]
            Map1 = open('用户信息/map1_s.txt','r')
            for each_line in Map1:
                (mima_, huiche_) = each_line.split('\n')
                list4.append(mima_)
            Map1.close()
            map=list4[zhanghao]
            for i in range(n):
                map1.append(list(map[i*n:(i+1)*n]))

            list5=[]
            Map2 = open('用户信息/map2_s.txt','r')
            for each_line in Map2:
                (mima_, huiche_) = each_line.split('\n')
                list5.append(mima_)
            Map2.close()
            map=list5[zhanghao]
            for i in range(n):
                map2.append(list(map[i*n:(i+1)*n]))

            for i in range(n):
                for j in range(n):
                    map1[i][j]=int(map1[i][j])
                    map2[i][j]=int(map2[i][j])
            Game.main(n,map1,map2,zhanghao)
if __name__ == "__main__":
    try:
        main()
    except SystemExit:
        pass
    except:
        traceback.print_exc()
        input()

![登陆界面](https://img-blog.csdn.net/20181019161117680?watermark/2/text/aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQyODQ3MjUy/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70)  
 choose.py



import numpy as np
import pygame
import sys
from pygame.locals import *
import traceback
import Game

pygame.init()
pygame.mixer.init()

#画出主界面
def draw_selector(position,decade,prompt):
decade+=1
str1=“(提示:w,s,a,d分别为上,下,左,右,q为标记,e为翻开)”
screen = pygame.display.set_mode([450,700])
screen.fill((237,237,237))
pygame.draw.rect(screen,(0,0,0),[100,100,100,300],5)
pygame.draw.rect(screen,(0,0,0),[250,100,100,300],5)
pygame.draw.line(screen,(0,0,0),(100,200),(200,200),5)
pygame.draw.line(screen,(0,0,0),(100,300),(200,300),5)
pygame.draw.line(screen,(0,0,0),(250,200),(350,200),5)
pygame.draw.line(screen,(0,0,0),(250,300),(350,300),5)

pygame.draw.line(screen,(0,0,0),(120,150),(180,150),20)
pygame.draw.line(screen,(0,0,0),(120,350),(180,350),20)
pygame.draw.line(screen,(0,0,0),(270,150),(330,150),20)
pygame.draw.line(screen,(0,0,0),(270,350),(330,350),20)
pygame.draw.line(screen,(0,0,0),(270,350),(330,350),20)
pygame.draw.line(screen,(0,0,0),(150,120),(150,180),20)
pygame.draw.line(screen,(0,0,0),(300,120),(300,180),20)
pygame.draw.rect(screen,(0,0,0),[100,450,250,100],5)
#定义字体跟大小
s_font1=pygame.font.Font('font.ttf',50)
s_font2=pygame.font.Font('font.ttf',16)
s_font3=pygame.font.Font('font.ttf',34)
#定义类容,是否抗锯齿,颜色
s_text1=s_font1.render(str(decade),True,(0,0,0))
s_text2=s_font1.render(str(position),True,(0,0,0))
s_text3=s_font1.render("开始游戏",True,(0,0,0))
s_text4=s_font2.render(str1,True,(0,0,0))
s_text5=s_font3.render(prompt,True,(255,0,0))
#将字放在窗口指定位置
screen.blit(s_text1,(135,220))
screen.blit(s_text2,(285,220))
screen.blit(s_text3,(120,470))
screen.blit(s_text4,(22,650))
screen.blit(s_text5,(100,50))





pygame.display.set_caption("选择难度")

pygame.display.flip()

def main(zhanghao,prompt=‘选择难度:’):
position=0
decade=1
draw_selector(position,decade,prompt)
while True:
for event in pygame.event.get():
if event.type ==pygame.QUIT:
pygame.quit()
sys.exit()

        elif event.type == MOUSEBUTTONDOWN:
            if event.button == 1:
                if 100<event.pos[0]<200 and 100<event.pos[1]<200 :
                    decade+=1
                    decade=decade%3
                    draw_selector(position,decade,prompt)
                elif 100<event.pos[0]<200 and 300<event.pos[1]<400:
                    decade-=1
                    decade=decade%3
                    draw_selector(position,decade,prompt)
                elif 250<event.pos[0]<350 and 100<event.pos[1]<200 :
                    position+=1
                    position=position%10
                    draw_selector(position,decade,prompt)
                elif 250<event.pos[0]<350 and 300<event.pos[1]<400 :
                    position-=1
                    position=position%10
                    draw_selector(position,decade,prompt)
                elif 100<event.pos[0]<350 and 450<event.pos[1]<550:
                    Game.main(N=10*(decade+1)+position,zhanghao=zhanghao)

![选择界面](https://img-blog.csdn.net/20181019161258195?watermark/2/text/aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQyODQ3MjUy/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70)  
 Game.py:



import numpy as np
import pygame
import sys
import traceback
import random
import choose
from pygame.locals import *

pygame.init()
pygame.mixer.init()
button_sound = pygame.mixer.Sound(“button.wav”)
button_sound.set_volume(0.2)
bomb_sound = pygame.mixer.Sound(“bomb.wav”)
bomb_sound.set_volume(0.2)

#绘制地图
def draw_map(screen,N):
screen.fill((237,237,237))
for i in range(N):
for j in range(N):
pygame.draw.rect(screen,(0,0,0),[i30,j30,29,29],1)

#翻开数字
def draw_sort(screen,x,y,N,map1,map2):
#定义字体跟大小
s_font=pygame.font.Font(‘font.ttf’,19)
#定义类容,是否抗锯齿,颜色
if map1[x][y]==0:
color=(86,98,166)
elif map1[x][y]==1:
color=(67,106,62)
elif map1[x][y]==2:
color=(15,170,209)
else:
color=(222,29,90)
s_text=s_font.render(str(map1[x][y]),True,color)
#将字放在窗口指定位置
screen.blit(s_text,(x30+9,y30+3))
if map2[x][y]==2:
map2[x][y]=1
Clean_select(screen,x,y,map2)
map2[x][y]=1
pygame.display.flip()
#翻开雷
def draw_bomb(screen,map1,N,zhanghao):
bomb=pygame.image.load(“bomb.png”).convert_alpha()
for i in range(N):
for j in range(N):
if map1[i][j]>=9:
screen.blit(bomb,(30i+1,30j+1))
bomb_sound.play(0)
pygame.display.flip()
pygame.time.wait(5000)
choose.main(zhanghao,“游戏失败!!”)
#绘制键盘选中项
def draw_select(screen,x,y):
pygame.draw.rect(screen,(0,0,0),[x30,y30,29,29],3)
pygame.display.flip()
#清除选中项,标记项
def Clean_select(screen,x,y,map2):
pygame.draw.rect(screen,(237,237,237),[x30,y30,29,29],3)
pygame.draw.rect(screen,(0,0,0),[x30,y30,29,29],1)
if map2[x][y]==2:
draw_sign(screen,x,y)
pygame.display.flip()
#绘制标记项
def draw_sign(screen,x,y):
pygame.draw.rect(screen,(237,0,0),[x30,y30,29,29],3)
pygame.display.flip()

#放入雷
def thunder(N,map1):
a=0
while(a!=N*N//6):
x=random.randint(0,N-1)
y=random.randint(0,N-1)
map1[x][y]=9
a=0
for i in range(N):
for j in range(N):
if map1[i][j]==9:
a+=1

#显示0旁边的类容
def show_around(screen,x,y,N,map1,map2):
if y+1<N and map1[x][y+1]!=9 and map2[x][y+1]!=1:
draw_sort(screen,x,y+1,N,map1,map2)
if map1[x][y+1]==0:
show_around(screen,x,y+1,N,map1,map2)
if y-1>=0 and map1[x][y-1]!=9and map2[x][y-1]!=1:
draw_sort(screen,x,y-1,N,map1,map2)
if map1[x][y-1]==0:
show_around(screen,x,y-1,N,map1,map2)
if x+1<N and map1[x+1][y]!=9and map2[x+1][y]!=1:
draw_sort(screen,x+1,y,N,map1,map2)
if map1[x+1][y]==0:
show_around(screen,x+1,y,N,map1,map2)
if x-1>=0 and map1[x-1][y]!=9and map2[x-1][y]!=1:
draw_sort(screen,x-1,y,N,map1,map2)
if map1[x-1][y]==0:
show_around(screen,x-1,y,N,map1,map2)
if x+1=0 and map1[x+1][y-1]!=9and map2[x+1][y-1]!=1:
draw_sort(screen,x+1,y-1,N,map1,map2)
if map1[x+1][y-1]==0:
show_around(screen,x+1,y-1,N,map1,map2)
if x+1<N and y+1<N and map1[x+1][y+1]!=9and map2[x+1][y+1]!=1:
draw_sort(screen,x+1,y+1,N,map1,map2)
if map1[x+1][y+1]==0:
show_around(screen,x+1,y+1,N,map1,map2)
if x-1>=0 and y-1>=0 and map1[x-1][y-1]!=9and map2[x-1][y-1]!=1:
draw_sort(screen,x-1,y-1,N,map1,map2)
if map1[x-1][y-1]==0:
show_around(screen,x-1,y-1,N,map1,map2)
if x-1>=0 and y+1<N and map1[x-1][y+1]!=9and map2[x-1][y+1]!=1:
draw_sort(screen,x-1,y+1,N,map1,map2)
if map1[x-1][y+1]==0:
show_around(screen,x-1,y+1,N,map1,map2)

#给map1赋值
def assignment(N,map1):
for i in range(N):
for j in range(N):
if(map1[i][j]>=9):
if j+1<N:
map1[i][j+1]+=1
if j-1>=0:
map1[i][j-1]+=1
if i+1<N:
map1[i+1][j]+=1
if i-1>=0:
map1[i-1][j]+=1
if i+1=0:
map1[i+1][j-1]+=1
if i+1<N and j+1<N:
map1[i+1][j+1]+=1
if i-1>=0 and j-1>=0:
map1[i-1][j-1]+=1
if i-1>=0 and j+1<N:
map1[i-1][j+1]+=1
for i in range(N):
for j in range(N):
if(map1[i][j]>=9):
map1[i][j]=9
#更新指定文件里面的数据
def update(zhanghao,data,file,N):
data_list=[]
data_s=open(file,‘r’)
for each_line in data_s:
(data_, huiche_) = each_line.split(‘\n’)
data_list.append(data_)
data_s.close()
if data!=N:
data_list[zhanghao]=conversion(data,N)
elif data==N:
data_list[zhanghao]=str(N)
data_s=open(file,‘w’)
for i in range(len(data_list)):
data_s.write(data_list[i]+‘\n’)
data_s.close()

#更新所有数据
def update2(zhanghao,map1,map2,N,address=‘用户信息/map1_s.txt’):
update(zhanghao,map1,‘用户信息/map1_s.txt’,N)
update(zhanghao,map2,‘用户信息/map2_s.txt’,N)
update(zhanghao,N,‘用户信息/N_s.txt’,N)

#将二维数组转换成字符串
def conversion(map,N):
Str=‘’
for i in range(N):
for j in range(N):
Str+=str(map[i][j])
return Str

#判断是否胜利
def is_win(map2,N):
sum=0
for i in range(N):
sum+=map2[i].count(1)
if sum==(NN-NN//6):
return True
return False

#主函数
def main(N,map1=[],map2=[],zhanghao=0):

if map1==[]:
    #储存“雷”状态的数组
    map1=list([])
    for i in range(N):
        map1.append([0]*N)
    #储存翻开状态的列表
    map2=list([])
    for i in range(N):
        map2.append([0]*N)
    thunder(N,map1)
    assignment(N,map1)

key_x=0
key_y=0

#定义窗口
screen = pygame.display.set_mode([30*N,30*N])

#定义窗口名字
pygame.display.set_caption("扫雷:("+str(N*N//6)+"个雷)")
draw_map(screen,N)

if map2!=[]:
    for i in range(N):
        for j in range(N):
            if map2[i][j]==1 and map1[i][j]<9:
                draw_sort(screen,i,j,N,map1,map2)                    
    for i in range(N):
        for j in range(N):
            if map2[i][j]==1 and map1[i][j]>=9:
                draw_bomb(screen,map1,N,zhanghao)

pygame.display.flip()    
while True:
    for event in pygame.event.get():

现在能在网上找到很多很多的学习资源,有免费的也有收费的,当我拿到1套比较全的学习资源之前,我并没着急去看第1节,我而是去审视这套资源是否值得学习,有时候也会去问一些学长的意见,如果可以之后,我会对这套学习资源做1个学习计划,我的学习计划主要包括规划图和学习进度表。

分享给大家这份我薅到的免费视频资料,质量还不错,大家可以跟着学习

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 29
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值