欢迎使用皮肤 Geek|
2024-02-21 18:22阅读: 48评论: 0推荐: 0

PySide基础三大件案例_计算器

描述

制作一个简单的计算器,要求可以输入0-9的数字和四则运算,=则输出计算结果,reset则清空计算器

展示

代码

from PySide6.QtWidgets import QApplication,QWidget
from Calculator_ui  import Ui_Form

class Claculator(QWidget,Ui_Form):#Mark 使用多重继承的特性进行调用
    def __init__(self):
        super().__init__()
        self.setupUi(self)  #使用多重继承的特性可以少掉实例化赋值的步骤
        self.result=''
        self.bind()

    def bind(self):
        self.num_0.clicked.connect(lambda:self.addNumber('0'))
        self.num_1.clicked.connect(lambda:self.addNumber('1'))
        self.num_2.clicked.connect(lambda:self.addNumber('2'))
        self.num_3.clicked.connect(lambda:self.addNumber('3'))
        self.num_4.clicked.connect(lambda:self.addNumber('4'))
        self.num_5.clicked.connect(lambda:self.addNumber('5'))
        self.num_6.clicked.connect(lambda:self.addNumber('6'))
        self.num_7.clicked.connect(lambda:self.addNumber('7'))
        self.num_8.clicked.connect(lambda:self.addNumber('8'))
        self.num_9.clicked.connect(lambda:self.addNumber('9'))

        self.Add.clicked.connect(lambda:self.addNumber('+'))
        self.Subtract.clicked.connect(lambda:self.addNumber('-'))
        self.multiply.clicked.connect(lambda:self.addNumber('*'))
        self.divide.clicked.connect(lambda:self.addNumber('/'))
        self.point.clicked.connect(lambda:self.addNumber('.'))
        self.reset.clicked.connect(self.reseted)    #Fixed 命名不要重复,否则python会找不到对应的变量或函数
        self.enter.clicked.connect(self.equal)


    def addNumber(self,number):
        self.output.clear()
        self.result+=number
        self.output.setText(self.result)

    def equal(self):
        self.numberResult=eval(self.result)
        self.output.setText(str(self.numberResult))

    def reseted(self):
        self.result = ''
        self.output.clear()

if __name__=='__main__':
    app=QApplication([])
    window=Claculator()
    window.show()
    app.exec()

备注

因为Python不会进行严格的类型检查,因此保证命名不要重复,否则会出现各种意想不到的问题

posted @   荒坂株式会社  阅读(48)  评论(0编辑  收藏  举报
点击右上角即可分享
微信分享提示
评论
收藏
关注
推荐
深色
回顶
收起