一个计算器的代码,只做注释

"""rapid_GUI program with pyqt,这本书的一些代码,整理一下,文字全部体现在注释里。"""
from __future__ import division
from PyQt4.QtCore import *
from PyQt4.QtGui import *
from math import *
import sys




class Form(QDialog):
def __init__(self, parent=None):
super(Form, self).__init__(parent)
self.browser = QTextBrowser()   # QTextBrowser是个文字浏览器,支持HTML标志,所以可以格式化
self.lineedit = QLineEdit("Type an expression and press Enter")
self.lineedit.selectAll()  # 文本处于选择状态,一点击提示文字就消失了
layout = QVBoxLayout()  # QVBoxLayout是一种布局类,这个是垂直布局。
layout.addWidget(self.browser)  #在布局上增加子类
layout.addWidget(self.lineedit)
self.setLayout(layout)
self.lineedit.setFocus()
self.connect(self.lineedit, SIGNAL("returnPressed()"), self.updateUi)
self.setWindowTitle("Calculate")


def updateUi(self):
try:
txt = self.lineedit.text()
self.browser.append("%s=<b>%s</b>" % (txt, eval(txt)))  # 字符串表达式求值,只要eval。经常忘
self.lineedit.selectAll()  # 我是加上的,输入一个,回车之后,要处于选择状态,方便后面的输入
except:
self.browser.append("<font color=red>%s is invalid!</font>" % txt)


if __name__ == "__main__":
app = QApplication(sys.argv)
form = Form()
form.show()

app.exec_()



好的,下面是一个简单的Vue计算器示例,已经加上了注释: ```html <template> <div> <h1>简易计算器</h1> <div> <input type="text" v-model="result" disabled /> </div> <div> <button @click="addNumber(1)">1</button> <button @click="addNumber(2)">2</button> <button @click="addNumber(3)">3</button> <button @click="addOperator('+')">+</button> </div> <div> <button @click="addNumber(4)">4</button> <button @click="addNumber(5)">5</button> <button @click="addNumber(6)">6</button> <button @click="addOperator('-')">-</button> </div> <div> <button @click="addNumber(7)">7</button> <button @click="addNumber(8)">8</button> <button @click="addNumber(9)">9</button> <button @click="addOperator('*')">*</button> </div> <div> <button @click="addNumber(0)">0</button> <button @click="clear">C</button> <button @click="calculate">=</button> <button @click="addOperator('/')">/</button> </div> </div> </template> <script> export default { data() { return { result: "", // 计算结果 currentNumber: "", // 当前输入的数字 operator: "", // 当前操作符 isOperatorClicked: false, // 是否点击了操作符 }; }, methods: { // 添加数字 addNumber(number) { if (this.isOperatorClicked) { // 如果已经点击了操作符,则清空当前数字 this.currentNumber = ""; this.isOperatorClicked = false; } this.currentNumber += number; this.result += number; }, // 添加操作符 addOperator(operator) { if (this.operator !== "") { // 如果已经有操作符,则计算结果 this.calculate(); } this.operator = operator; this.isOperatorClicked = true; this.result += operator; }, // 计算结果 calculate() { if (this.operator === "+") { this.result = String( Number(this.result) + Number(this.currentNumber) ); } else if (this.operator === "-") { this.result = String( Number(this.result) - Number(this.currentNumber) ); } else if (this.operator === "*") { this.result = String( Number(this.result) * Number(this.currentNumber) ); } else if (this.operator === "/") { this.result = String( Number(this.result) / Number(this.currentNumber) ); } this.currentNumber = ""; this.operator = ""; this.isOperatorClicked = true; }, // 清空计算器 clear() { this.result = ""; this.currentNumber = ""; this.operator = ""; this.isOperatorClicked = false; }, }, }; </script> ``` 这个计算器支持加、减、乘、除四个基本运算,可以在输入数字后点击操作符进行计算,也可以在输入数字后继续输入数字,直到点击操作符进行计算。点击 C 按钮可以清空计算器
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值