python中猜数游戏代码_pycharm实现猜数游戏

本文实例为大家分享了pycharm实现猜数游戏的具体代码,供大家参考,具体内容如下

1. 设计界面

如下所示,利用QTdesigner设计的界面:

然后将设计好的界面转换为.py文件:

guess_number.py

# -*- coding: utf-8 -*-

# Form implementation generated from reading ui file 'guess_number.ui'

#

# Created by: PyQt5 UI code generator 5.15.2

#

# WARNING: Any manual changes made to this file will be lost when pyuic5 is

# run again. Do not edit this file unless you know what you are doing.

from PyQt5 import QtCore, QtGui, QtWidgets

class Ui_MainWindow(object):

def setupUi(self, MainWindow):

MainWindow.setObjectName("MainWindow")

MainWindow.resize(580, 328)

icon = QtGui.QIcon()

icon.addPixmap(QtGui.QPixmap("../../../Icon/Comment.svg"), QtGui.QIcon.Normal, QtGui.QIcon.Off)

icon.addPixmap(QtGui.QPixmap("../../../Icon/Comment.svg"), QtGui.QIcon.Normal, QtGui.QIcon.On)

icon.addPixmap(QtGui.QPixmap("../../../Icon/Comment.svg"), QtGui.QIcon.Disabled, QtGui.QIcon.Off)

icon.addPixmap(QtGui.QPixmap("../../../Icon/Comment.svg"), QtGui.QIcon.Disabled, QtGui.QIcon.On)

icon.addPixmap(QtGui.QPixmap("../../../Icon/Comment.svg"), QtGui.QIcon.Active, QtGui.QIcon.Off)

icon.addPixmap(QtGui.QPixmap("../../../Icon/Comment.svg"), QtGui.QIcon.Active, QtGui.QIcon.On)

icon.addPixmap(QtGui.QPixmap("../../../Icon/Comment.svg"), QtGui.QIcon.Selected, QtGui.QIcon.Off)

icon.addPixmap(QtGui.QPixmap("../../../Icon/Comment.svg"), QtGui.QIcon.Selected, QtGui.QIcon.On)

MainWindow.setWindowIcon(icon)

self.centralwidget = QtWidgets.QWidget(MainWindow)

self.centralwidget.setObjectName("centralwidget")

self.gridLayout_4 = QtWidgets.QGridLayout(self.centralwidget)

self.gridLayout_4.setObjectName("gridLayout_4")

spacerItem = QtWidgets.QSpacerItem(20, 50, QtWidgets.QSizePolicy.Minimum, QtWidgets.QSizePolicy.Expanding)

self.gridLayout_4.addItem(spacerItem, 0, 1, 1, 1)

spacerItem1 = QtWidgets.QSpacerItem(181, 20, QtWidgets.QSizePolicy.Expanding, QtWidgets.QSizePolicy.Minimum)

self.gridLayout_4.addItem(spacerItem1, 1, 3, 1, 1)

spacerItem2 = QtWidgets.QSpacerItem(180, 20, QtWidgets.QSizePolicy.Expanding, QtWidgets.QSizePolicy.Minimum)

self.gridLayout_4.addItem(spacerItem2, 1, 0, 1, 1)

self.gridLayout_3 = QtWidgets.QGridLayout()

self.gridLayout_3.setObjectName("gridLayout_3")

spacerItem3 = QtWidgets.QSpacerItem(17, 37, QtWidgets.QSizePolicy.Minimum, QtWidgets.QSizePolicy.Expanding)

self.gridLayout_3.addItem(spacerItem3, 0, 2, 1, 1)

self.gridLayout_2 = QtWidgets.QGridLayout()

self.gridLayout_2.setObjectName("gridLayout_2")

self.button = QtWidgets.QPushButton(self.centralwidget)

self.button.setObjectName("button")

self.gridLayout_2.addWidget(self.button, 2, 1, 1, 1)

self.inputnumber = QtWidgets.QLineEdit(self.centralwidget)

self.inputnumber.setObjectName("inputnumber")

self.gridLayout_2.addWidget(self.inputnumber, 0, 0, 1, 3)

spacerItem4 = QtWidgets.QSpacerItem(40, 20, QtWidgets.QSizePolicy.Expanding, QtWidgets.QSizePolicy.Minimum)

self.gridLayout_2.addItem(spacerItem4, 2, 2, 1, 1)

spacerItem5 = QtWidgets.QSpacerItem(40, 20, QtWidgets.QSizePolicy.Expanding, QtWidgets.QSizePolicy.Minimum)

self.gridLayout_2.addItem(spacerItem5, 2, 0, 1, 1)

spacerItem6 = QtWidgets.QSpacerItem(20, 40, QtWidgets.QSizePolicy.Minimum, QtWidgets.QSizePolicy.Expanding)

self.gridLayout_2.addItem(spacerItem6, 1, 1, 1, 1)

self.gridLayout_3.addLayout(self.gridLayout_2, 1, 1, 2, 2)

spacerItem7 = QtWidgets.QSpacerItem(37, 17, QtWidgets.QSizePolicy.Expanding, QtWidgets.QSizePolicy.Minimum)

self.gridLayout_3.addItem(spacerItem7, 1, 3, 1, 1)

spacerItem8 = QtWidgets.QSpacerItem(37, 17, QtWidgets.QSizePolicy.Expanding, QtWidgets.QSizePolicy.Minimum)

self.gridLayout_3.addItem(spacerItem8, 1, 0, 1, 1)

spacerItem9 = QtWidgets.QSpacerItem(17, 37, QtWidgets.QSizePolicy.Minimum, QtWidgets.QSizePolicy.Expanding)

self.gridLayout_3.addItem(spacerItem9, 3, 1, 1, 1)

self.gridLayout_4.addLayout(self.gridLayout_3, 1, 1, 1, 2)

spacerItem10 = QtWidgets.QSpacerItem(20, 49, QtWidgets.QSizePolicy.Minimum, QtWidgets.QSizePolicy.Expanding)

self.gridLayout_4.addItem(spacerItem10, 2, 2, 1, 1)

MainWindow.setCentralWidget(self.centralwidget)

self.menubar = QtWidgets.QMenuBar(MainWindow)

self.menubar.setGeometry(QtCore.QRect(0, 0, 580, 28))

self.menubar.setObjectName("menubar")

MainWindow.setMenuBar(self.menubar)

self.statusbar = QtWidgets.QStatusBar(MainWindow)

self.statusbar.setObjectName("statusbar")

MainWindow.setStatusBar(self.statusbar)

self.retranslateUi(MainWindow)

QtCore.QMetaObject.connectSlotsByName(MainWindow)

def retranslateUi(self, MainWindow):

_translate = QtCore.QCoreApplication.translate

MainWindow.setWindowTitle(_translate("MainWindow", "猜数游戏"))

self.button.setText(_translate("MainWindow", "我猜"))

self.inputnumber.setText(_translate("MainWindow", "在这里输入数字"))

2.对ui界面的功能具体实现

如果直接使用生成好的.py文件使用起来不是很方便,修改界面以后重新生成的.py文件会直接覆盖,这里我采用一个新类直接获取前面设计好的界面从而实现算法与界面程序分离,先上代码。

main.py

import sys

import guess_number

from PyQt5.QtWidgets import QApplication, QMainWindow, QMessageBox, QWidget

from random import randint

class guess_ui(QMainWindow):

def __init__(self):

# get ui from guess_number

super().__init__()

self.num = randint(1, 100)

self.MainWindow = QMainWindow()

self.InitUI()

def InitUI(self):

ui = guess_number.Ui_MainWindow()

ui.setupUi(self)

button = self.findChild(QWidget, 'button')

button.clicked.connect(self.show_message)

self.show()

# self.MainWindow.show()

def show_message(self):

inputnumber = self.findChild(QWidget, 'inputnumber')

guessnumber = int(inputnumber.text())

print(guessnumber)

if guessnumber > self.num:

QMessageBox.about(self, 'see the result', 'bigger!')

inputnumber.setFocus()

elif guessnumber < self.num:

QMessageBox.about(self, 'see the result', 'smaller!')

inputnumber.setFocus()

else:

QMessageBox.about(self, 'see the result', 'true')

self.num = randint(1, 100)

inputnumber.clear()

inputnumber.setFocus()

def closeEvent(self, event):

reply = QMessageBox.question(self, 'confirm', 'Are you sure?', QMessageBox.Yes | QMessageBox.No)

if reply == QMessageBox.Yes:

event.accept()

else:

event.ignore()

if __name__ == '__main__':

app = QApplication(sys.argv)

guess = guess_ui()

sys.exit(app.exec_())

3.对部分代码的解析

class guess_ui(QMainWindow):

将此类直接从QMainWindow继承过来可以实现对QT事件的重写,事件重现代码如下:

def closeEvent(self, event):

reply = QMessageBox.question(self, 'confirm', 'Are you sure?', QMessageBox.Yes | QMessageBox.No)

if reply == QMessageBox.Yes:

event.accept()

else:

event.ignore()

在界面文件中按钮的定义是直接add进去的,所以定义某个控件功能首先要获取该控件,代码如下所示:

button = self.findChild(QWidget, 'button')

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个简单的Java游戏的图形界面实现代码: ```java import java.awt.*; import java.awt.event.*; import javax.swing.*; public class GuessNumberGUI extends JFrame implements ActionListener { private JTextField inputField; private JLabel outputLabel; private int randomNumber; private int numGuesses; public GuessNumberGUI() { super("数字游戏"); randomNumber = (int) (Math.random() * 100) + 1; numGuesses = 0; JPanel panel = new JPanel(); panel.setLayout(new GridLayout(3, 1)); JLabel promptLabel = new JLabel("输入一个 1 到 100 之间的整数:"); inputField = new JTextField(10); inputField.addActionListener(this); outputLabel = new JLabel("你还没有过。"); outputLabel.setHorizontalAlignment(SwingConstants.CENTER); panel.add(promptLabel); panel.add(inputField); panel.add(outputLabel); setContentPane(panel); pack(); setVisible(true); } public void actionPerformed(ActionEvent e) { int guess; String inputString = inputField.getText().trim(); try { guess = Integer.parseInt(inputString); } catch (NumberFormatException ex) { outputLabel.setText("输入必须是一个整数。"); return; } numGuesses++; if (guess == randomNumber) { outputLabel.setText("恭喜你对了!你一共了 " + numGuesses + " 次。"); inputField.setEnabled(false); } else if (guess < randomNumber) { outputLabel.setText("你小了。你已经了 " + numGuesses + " 次。"); } else { outputLabel.setText("你大了。你已经了 " + numGuesses + " 次。"); } inputField.setText(""); } public static void main(String[] args) { new GuessNumberGUI(); } } ``` 这个程序使用了Java的Swing库来创建一个简单的图形用户界面。程序生成一个 1 到 100 之间的随机数,并要求用户输入一个整数来测这个随机数。每次用户测时,程序会告诉用户他们的数字是太大了还是太小了,直到用户对为止。程序还会记录用户测的次数,并在用户对时显示出来。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值