pycharm实现猜数游戏

古剑山,俗称 "鸡公嘴 ",山脉由贵州境内而来,最高海拔1100多米,最低海拔700多米。离开綦江县城不到10公里,映入你眼帘的是一幅墨绿的雄鸡图。在蓝天白云衬托下,鸡冠鸡嘴翅膀的轮廓线条,勾勒出雄鸡凌空屹立引颈长啼的倩影。

本文实例为大家分享了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')

到此这篇关于pycharm实现猜数游戏就介绍到这了。伟人之所以伟大,是因为他与别人共处逆境时,别人失去了信心,他却下决心实现自己的目标。更多相关pycharm实现猜数游戏内容请查看相关栏目,小编编辑不易,再次感谢大家的支持!

您可能有感兴趣的文章
Python Pycharm虚拟下百度飞浆PaddleX安装报错问题及处理方法(亲测100%有效)

pycharm中leetcode插件使用图文详解

最新PyCharm从安装到PyCharm永久激活再到PyCharm官方中文汉化详细好代码教程

详解pycharm的python包opencv(cv2)无代码提示问题的解决

pycharm中选中一个单词替换所有重复单词的实现方法