Python-井字棋

井字棋

  • 1.设计登录界面
    • 1.1导入需要的工具包
    • 1.2窗口显示
    • 1.3登录界面图片显示
    • 1.6标签按钮输入框显示
  • 2.登录功能实现
    • 2.1用户数据存储
  • 2.2登录和注册
    • 2.2.1登录功能实现
    • 2.2.2注册功能实现
  • 3.井字棋游戏
    • 3.1 导入需要的工具包
    • 3.2 窗口显示
    • 3.2 按钮标签显示
    • 3.3 棋盘设置初始状态
    • 3.4 游戏设计
      • 3.4.1创建白布
      • 3.4.2 画出九宫格
  • 在每个格子中心绘制数字或 "X"
  • 3.6设置输赢条件
  • 3.7 进一步处理用户输入
  • 3.8设置AI步数
  • 3.9 清空棋盘状态
  • 效果图

1.设计登录界面

1.1导入需要的工具包

import tkinter as tk
from PIL import Image, ImageTk
import pickle
from tkinter import messagebox
import subprocess

1.2窗口显示

window = tk.Tk()
window.title("Welcome")
window.geometry('500x600')

1.3登录界面图片显示

image = Image.open("welcome.gif")
photo = ImageTk.PhotoImage(image)

函数解析 ImageTk.PhotoImage 是 Python 中用于处理图像的模块,通常与 PIL(Python Imaging
Library)一起使用。它允许你在 Tkinter 程序中加载和显示图像。
1.5 用户名设置默认值

value = "GaoYue"
entry_var = tk.StringVar(window)
entry_var.set(value)

解释:
创建了一个StringVar对象entry_var,用于绑定到一个Entry控件,以便可以在用户输入时更新该控件的值。然后,给entry_var设置了一个初始值value,这样在Entry控件中显示的文本就是value的值,并设置初始值为@qq.com,这样在Entry控件中显示的文本就是。

1.6标签按钮输入框显示

label1_image = tk.Label(window,image=photo)
label1_image.place(x=10,y=10)
label2 = tk.Label(window,text='User name',width=10,height=5)
label2.place(x=40,y=130)
label3 = tk.Label(window,text='password',width=10,height=5)
label3.place(x=40,y=180)
label4 = tk.Entry(window,width=30,bd=5)
label4.place(x=140,y=210)
label5 = tk.Entry(window,textvariable=entry_var,width=30,bd=5)
label5.place(x=140,y=160)

button1 = tk.Button(window,text='Loign',width=10,command=usr_login)
button1.place(x=140,y=280)
button2 = tk.Button(window,text='Sign up',width=10,command=usr_sign_up)
button2.place(x=250,y=280)

2.登录功能实现

2.1用户数据存储

def usr_login():
    usr_name = label5.get()
    usr_pwd=label4.get()
    print(usr_name)
    try:
        with open("usrs_info.pickle",'rb') as usr_file:
            print("1")
            usrs_info = pickle.load(usr_file)
            print(usrs_info)
    except FileNotFoundError:
        with open("usrs_info.pickle",'wb') as usr_file:
            print("2")
            usrs_info = {'admin':'admin'}
            pickle.dump(usrs_info,usr_file)

解释:

两个输入框(label5,label4)使用get()函数,获取用户输入的数据,接下来使用使用了Python中的异常处理机制。在try使用with语句打开"usrs_info.pickle"文件,设置为只读二进制模式,将”usrs_info.pickle”二进制文件加载到内存里面,转换到usrs_info变量中,输出出来。当读取的文件不存在报错时,跳转到except代码块中执行相应的异常处理,使用with语句打开二进制写入模式打开文件,文件不存在时创建相对应文件,用一个变量(usrs_info)接收一个字典(
{‘admin’:‘admin’})用来存储用户信息或者账户信息,用于验证用户身份,将字典序列化为字节流(二进制数据)并写入usr_file文件中永久保存。

2.2登录和注册

2.2.1登录功能实现

print("ok")
print("usr_name:",usr_name)
if usr_name in usrs_info:
    print("3")
    if usr_pwd  == usrs_info[usr_name]:
        tk.messagebox.showinfo(title="Welcome",message="How are you"+usr_name)
        tk.messagebox.showinfo(title="Game Start", message="Let's start the game!")
        subprocess.run(["python", "飞机大战.py"])
    else:
        tk.messagebox.showerror(message="Error,your password is wrong,try again.")
else:
    print("4")
    is_sign_up = tk.messagebox.askyesno(title="Welcome",message="You have not sign up yet.sign up today?")

解释:
If语句如果用户名在字典中执行下一个if语句用户密码是否等于usrs_info中键usr_name的值,如果等于弹出消息框((title=“Welcome”,message=“How
are you”+usr_name),(title=“Game Start”, message=“Let’s start the
game!”),使用subprocess.run函数以python解释器,执行井字棋.py文件,如果不等于弹出消息框(message=“Error,your
password is wrong,try
again.”),如果第一个if语句没有达到条件,弹出一个对话框,内容是title=“Welcome”,message=“You have
not sign up yet.sign up today?”。

2.2.2注册功能实现

def sign_up():
    nn = entry9.get()
    np = entry10.get()
    npf = entry11.get()
    with open('usrs_info.pickle','rb') as usr_file:
        exist_usr_info = pickle.load(usr_file)
    if np != npf:
        tk.messagebox.showerror("Error","The user has already signed up!")
    elif nn in exist_usr_info:
        print("已经注册过了")
        tk.messagebox.showerror("Error","The user has already signed up!")
    else:
        exist_usr_info[nn] = np
        with open("usrs_info.pickle","wb") as usr_file:
            pickle.dump(exist_usr_info,usr_file)
        tk.messagebox.showinfo("Welcome","You have successfully signed up!")
        window.destroy()
button3 = tk.Button(window, text='Sign up', width=10,command=sign_up)
button3.place(x=140, y=150)
print("开始注册")

解释:
三个输入框获取用户输入的用户名,注册密码,重复密码,打开二进制文件,将二进制文件数据转换为python对象,用一个变量exist_usr_info保存,然后if判断注册密码是否与重复密码相等,如果不相等就弹出消息框(“Error”,“The
user has already signed
up!”),反之文件中的用户名中的密码等于注册密码,将变量exist_usr_info中的数据通过with语句和pickle函数保存在二进制文件中,然后弹出消息框(“Welcome”,“You
have successfully signed up!”),窗口销毁,将函数sign_up与按钮进行连接,最后输入开始注册。

3.井字棋游戏

3.1 导入需要的工具包

import tkinter as tk
from tkinter import messagebox

3.2 窗口显示

window = tk.Tk()
window.geometry("600x500")
window.title("Welcome")

3.2 按钮标签显示

label2 = tk.Label(text="请输入要落下棋子的位置(1-9):", width=30, height=2)
label2.pack()
label2.place(x=190, y=310)
entry2 = tk.Entry(width=20)
entry2.pack()
entry2.place(x=220, y=350)
button11 = tk.Button(text="落下棋子", width=10, height=2,command=message2)
button11.pack()
button11.place(x=250, y=380)
button22 = tk.Button(text="重新开始", width=10, height=2)
button22.pack()
button22.place(x=250, y=430)

解释: 设置标签和按钮,按钮与函数相连接

3.3 棋盘设置初始状态

gameover = False
board = ['']*9
step = 0

解释: 设置游戏初始化为结束,设置棋盘状态为九个空字符串的列表,step为初始化棋盘步数为0

3.4 游戏设计

3.4.1创建白布

canvas = tk.Canvas(window, width=300, height=300, bg="white")
canvas.pack()

函数解析: tk.Canvas 是 Tkinter
中用于绘制图形的组件,你可以在其中绘制直线、矩形、椭圆等形状,也可以放置文本、图像等元素。

3.4.2 画出九宫格

def draw_nume(canvas,width,height,line_color='black'):
    cell_width = width / 3
    cell_height = height / 3

    for i in range(3):
        x = i * cell_width
        canvas.create_line(x, 0, x, height, fill=line_color)  # 垂直线
    for i in range(3):
        y = i * cell_height
        canvas.create_line(0, y, width, y, fill=line_color)  # 水平线

解释:
定义一个draw_nume函数传入形参(canvas,width,height,line_color=‘black’),’line_color='black’表示线条颜色,width,height,cell_width
= width / 3和cell_height = height / 3计算了每个单元格的宽度和高度,第一个for循环是画垂直线(起点坐标,终点坐标) fill=line_color填充方式为线条,计算当前列的
x 坐标为 i * cell_width。第二个for循环是画水平线,计算当前行的 y坐标为 i *
cell_height,canvas.create_line()画水平线。

在每个格子中心绘制数字或 “X”

for i in range(3):
    for j in range(3):
        x = i * cell_width + cell_width / 2
        y = j * cell_height + cell_height / 2
        index = i * 3 + j
        if board[index] == 'X':
            canvas.create_text(y, x, text="X", font=("Helvetica", 20))
        else:
            canvas.create_text(y, x, text=str(index + 1), font=("Helvetica", 20))

解释: 第一个for循环为行的中心位置,第二个for循环为列的中心位置,在x,y找到中心位置 index = i * 3 +
j是在九宫格上写上数字的索引,如果board[index] == ‘X’:,就在x,y的中心位置画X,如果不是在index索引加一。
3.5设置输入限制

def message():
    Iemet = entry2.get()
    if not Iemet.isdigit():
        tk.messagebox.showinfo("输入错误", "请输入一个数字。")
    elif int(Iemet) > 9:
        tk.messagebox.showinfo("输入错误", "输入的数字不能大于 9。")

解释: 如果判断不是数字,弹出消息框(“输入错误”, “请输入一个数字。”),接着判断输入的是大于9 的弹出消息框(“输入错误”,
“输入的数字不能大于 9。”)

3.6设置输赢条件

def iswins():
    global gameover
    wins = [[0,1,2],[3,4,5],[6,7,8],[0,3,6],[1,4,7],[2,5,8],[0,4,8],[2,4,6]]
    for w in wins:
        if (board[w[0]]!=" " and board[w[0]]==board[w[1]]==board[w[2]]):
            gameover = True
            tk.messagebox.showinfo(title="你别挣了",message="我赢了")
            return
    if step>=5:
        gameover =True
        return tk.messagebox.showinfo(title="你别挣了",message="都没有赢了")
    return

解释:
定义全局变量gameover,列出所有的用户赢的可能,for循环用与循环遍历wins列表,if条件使用索引board[w[0]],w的第一个数不能为空,判断board[w[0]]的第一个数和第二个数和第三个数是否相等,如果相等就是wins列表中的一个赢的可能,弹出消息框(title=“你别挣了”,message=“我赢了”),返回,第二个if条件如果我方步数大于等于5返回消息框(title=“你别挣了”,message=“都没有赢了”),返回。

3.7 进一步处理用户输入

def message2():
    global board
    global step
    Iemet = entry2.get()
    if Iemet.isdigit():
        number = int(Iemet)
        if 1 <= number <= 9:
            index = number - 1
            board[index] = 'X'
            draw_nume(canvas, 300, 300)
    is_Win()
    step +=1

解释:
定义两个全局变量,获取输入框文本,if语句检查用户输入的文本是否为数字,接着if语句判断是否在1到9之间(包括1-9),井字棋游戏板上的索引位置标记为
‘X’,表示用户的棋子,这是一个函数调用,用来在画布上绘制新的游戏板,调用一个函数is_Win(),用来检查是否获胜,这一行代码增加游戏的步数,以便在每一步后进行检查。将函数放置在按钮上。

3.8设置AI步数

index = ai.AI().decide("AI","高越",board)
r = 20
canvas.create_oval()
board[index] = "AI"
iswins()

解释: 调用了 ai.AI().decide(“AI”,“高越”,board),圆的半径为20,设置棋盘数据为”AI”。

3.9 清空棋盘状态

def reset():
    global canvas
    canvas.delete('A')

使用canvas.delete函数清空棋盘状态

效果图

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/747294.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Adobe AIR是什么?能做什么?

Flash&#xff08;Animate&#xff09;软件能制作二维动画以及普通的互动课件是多数人了解的&#xff0c;其实Adobe还有一个AIR平台&#xff0c;可以用来开发更多不同的内容&#xff0c;这里就自己理解和掌握的信息分享一下AIR平台。 基本介绍 Adobe AIR是和Flash制作软件相依…

基于UDP的网络聊天室(多线程实现收和发消息)

要求&#xff1a;1.有新用户登录&#xff0c;其他在线的用户可以收到登录信息 2.有用户群聊&#xff0c;其他在线的用户可以收到群聊信息 3.有用户退出&#xff0c;其他在线的用户可以收到退出信息 4.服务器可以发送系统信息 效果图&#xff1a; service.c #include <head…

Day5:有效的字母异位词 242 两个数组的交集 349 快乐数 202 两数之和1

题目242. 有效的字母异位词 - 力扣&#xff08;LeetCode&#xff09; class Solution { public:bool isAnagram(string s, string t) {//把数组当成哈希表&#xff0c;用两个数组来存储取模后的字母对应的数量//26个字母&#xff0c; 模25 0~25int arrs[26];int arrt[26];for(…

<电力行业> - 《第4课:什么是电力?什么是发输变配用5环节?》

1 什么是电力&#xff1f; 我们对于平日生活中离不开的电很熟悉&#xff0c;但是电力是什么&#xff1f; 其实&#xff0c;电力就是电能作为动力的能源。电力就是我们说的电&#xff0c;不过更多了系统化。 19世纪70年代&#xff0c;电力的发明和应用掀起了第二次工业化高潮。…

MySQL之可扩展性(四)

可扩展性 向外扩展 分片?还是不分片&#xff1f; 这是一个问题&#xff0c;对吧&#xff1f;答案很简单:如非必要&#xff0c;尽量不分片。首先看是否能通过性能调优或者更好的应用或数据库设计来推迟分片。如果能足够长时间地推迟分片&#xff0c;也许可以直接购买更大地服…

springcloud第4季 springcloud-alibaba之openfegin+sentinel整合案例

一 介绍说明 1.1 说明 1.1.1 消费者8081 1.1.2 openfegin接口 1.1.3 提供者9091 9091微服务满足&#xff1a; 1 openfegin 配置fallback逻辑&#xff0c;作为统一fallback服务降级处理。 2.sentinel访问触发了自定义的限流配置&#xff0c;在注解sentinelResource里面配置…

吴恩达机器学习 第三课 week2 推荐算法(下)

目录 01 学习目标 02 基于内容的过滤算法 03 实现“电影推荐系统” 3.1 问题描述 3.2 算法实现 04 大项目&#xff08;数据很大&#xff09;的推荐方法※ 4.1 方法原理 4.2 实施示例 05 总结 01 学习目标 &#xff08;1&#xff09;理解基于内容的过滤算法&#xff08…

(四十六)Vue Router组件所独有的两个钩子activate、deactivated

文章目录 activated钩子函数deactivated钩子函数demo 上一篇&#xff1a;&#xff08;四十五&#xff09;Vue Router之编程式路由导航 Vue Router提供了两个钩子函数&#xff0c;分别是activated和deactivated。 这两个钩子函数可以用于在路由组件的激活状态发生变化时执行相…

前端开发实战项目:实时天气预报应用

引言 在本实战项目中&#xff0c;我们将开发一个实时天气预报应用。这个项目将帮助你掌握前端开发的核心技能&#xff0c;包括HTML、CSS、JavaScript&#xff0c;以及如何使用API来获取实时数据。通过这个项目&#xff0c;你将学会如何构建用户界面、处理用户交互、以及与第三…

HarmonyOS Next开发学习手册——通过startAbility拉起文件处理类应用

使用场景 开发者可以通过调用startAbility接口&#xff0c;由系统从已安装的应用中寻找符合要求的应用来实现打开特定文件的意图&#xff0c;例如&#xff1a;浏览器下应用下载PDF文件&#xff0c;可以调用此接口选择文件处理应用打开此PDF文件。开发者需要在请求中设置待打开…

IO-Link ISDU

目录 一、引言 二、ISDU定义与功能 三、ISDU指令构成 四、ISDU应用场景 五、ISDU优势 六、总结 一、引言 IO-Link技术作为工业自动化领域的创新通信标准&#xff0c;通过单一电缆实现了设备层级的透明化通信。其中&#xff0c;Indexed Service Data Unit&#xff08;ISDU…

目标检测mAP

【目标检测】目标检测算法评估指标(性能度量) AP&#xff0c;mAP 详细介绍_ap和map的区别-CSDN博客 目标检测中的mAP | Clouds Blog 目标检测AP如何理解&#xff1f;_置信度与ap-CSDN博客 一、IOU (Intersection Over Union, 交并比) 二、查准率和查全率 True Positive (TP…

力扣随机一题 6/26 哈希表 数组 思维

博客主页&#xff1a;誓则盟约系列专栏&#xff1a;IT竞赛 专栏关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ 题目一&#xff1a; 2869.收集元素的最少操作次数【简单】 题目&#xff…

Scania斯堪尼亚SHL题库综合能力性格测试真题题型解析及面试经验

一、走进Scania斯堪尼亚 Scania是一家成立于1891年的瑞典公司&#xff0c;专注于重型卡车和巴士的制造&#xff0c;以其模块化系统和环保设计闻名。作为全球领先的运输解决方案提供商&#xff0c;Scania不仅提供高质量的车辆&#xff0c;还提供相关服务和融资解决方案。公司秉…

我对AI赋能的未来畅想

个人名片 &#x1f393;作者简介&#xff1a;java领域优质创作者 &#x1f310;个人主页&#xff1a;码农阿豪 &#x1f4de;工作室&#xff1a;新空间代码工作室&#xff08;提供各种软件服务&#xff09; &#x1f48c;个人邮箱&#xff1a;[2435024119qq.com] &#x1f4f1…

经验分享,在线word转图片

这里分享一个在线word转图片的网站&#xff0c;比较好用 网址&#xff1a;http://www.docpe.com/word/word-to-image.aspx 截图&#xff1a;

一加全机型TWRP合集/橙狐recovery下载-20240603更新-支持一加12/Ace3V手机

TWRP是目前安卓平台的刷机神器&#xff0c;可快速刷写第三方ROM或官方系统&#xff0c;刷入TWRP之前需要解锁BL&#xff0c;目前已适配一加多个机型。ROM乐园小编20240603整理&#xff0c;涵盖一加1到一加Ace3V多机型专用TWRP文件&#xff0c;个人机型橙狐recovery适配相对完整…

react学习——17react中todoList案列

1、项目目录 2、App.js //创建“外壳”组件APP import React, {Component} from "react"; //引入Header组件 import Header from "./components/Header"; //引入List组件 import List from "./components/List"; //引入Footer组件 import Foot…

[极客大挑战 2020]Roamphp2-Myblog

又来喽 经过一番测试&#xff0c;发现文件包含&#xff0c;使用伪协议读取文件 例&#xff1a;php://filter/readconvert.base64-encode/resourcelogin //这里我只写php部分 //login.php <?php require_once("secret.php"); mt_srand($secret_seed); $_SESSION…

Kubernetes之Controller详解

本文尝试从Kubernetes Controller的种类、交互逻辑、最佳实践、伪代码示例及历史演进5个方面对其进行详细阐述&#xff0c;希望对您有所帮助&#xff01; 一、Kubernetes Controller种类 Kubernetes Controller Manager 是 Kubernetes 集群的核心组件之一&#xff0c;负责管理…