Python实现两款计算器功能示例
作者:海燕。 发布时间:2023-01-18 06:18:39
标签:Python,计算器
本文实例为大家分享了Python实现计算器功能示例代码,供大家参考,具体内容如下
1.简单计算器
#计算一个表达式的时候,首先肯定是先算括号里面的,再算乘除法,后算加减法
import re
# 1.去括号
def remove_kuohao(expression):
'''
这是一个去除括号的函数
:param expression: 传进来的表达式
:return: 计算后的结果
'''
while True:
ret = re.search(r'\([^(]*?\)',expression) #先利用正则匹配到式子里面的括号
if ret: #如果有括号
re_expression = ret.group() #先把找到的括号group()一下得到
# print(re_expression)
res = jianhua(re_expression.strip('()')) #括号里面有*/-+都不一定,就又定义了一个简化这个表达式的函数
# 如果是乘法就执行乘法运算,如果是除法运算就执行除法等,这样的话就直接调用jianhua这个函数了,当然这个式子
# 有括号,顺便把括号也去了,直接计算去掉括号后的式子
expression = expression.replace(re_expression,str(res)) #把计算出来的结果放回去:就是把原来的括号里的表达式
# 替换成现在计算的结果
# print(expression)
continue
break
res = jianhua(expression)
return res
#简化算法
def jianhua(re_expression):
while True:
# 匹配乘除法
ret = re.search(r'\d+\.*?\d*[*/]\-?\d+\.?\d*', re_expression) #利用正则匹配乘除法
if ret: # 如果匹配到有*或/就执行下面的代码
chengchu_expression = ret.group() #就先group一下得到有乘除法的表达式
res = chengchu(chengchu_expression) #调用乘除法的函数计算
re_expression = re_expression.replace(chengchu_expression, str(res)) #吧有乘除法的表达式和计算出来的结果替换
re_expression =chulifuhao(re_expression) #在调用处理符号的函数
# print(re_expression)
continue
break
# 匹配加减法
num = re.findall(r'[+-]?\d+\.?\d*', re_expression)#在没有乘除法的时候,就让匹配加减法,
if len(num) > 1: #如果匹配到的表达式的长度大于1,不过是加法还是减法,都让计算加法。因为float啥结果就是啥
mynum = 0
for i in num:
mynum += float(i)
return mynum
else:
return num[0]
# 3.计算两个数的+-*/
def chengchu(expression):
if '*' in expression:
x,y = expression.split('*')
return float(x)*float(y) #返回乘法运算的结果 ,让res接收
if '/' in expression:
x, y = expression.split('/')
return float(x)/float(y) #返回乘法运算的结果 ,让res接收
def chulifuhao(expression):
if '--' in expression:
expression = expression.replace('--','+')
if '++' in expression:
expression = expression.replace('++','+')
if '+-' in expression:
expression = expression.replace('+-','-')
if '-+' in expression:
expression = expression.replace('-+','-')
return expression #返回结果
cmd = input('请输入你要计算的表达式:>>')
# s = '1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)/ (16-3*2) )'
new_s = cmd.replace(' ', '') #先将所有的空格去了
# print(new_s)
ret = remove_kuohao(new_s) #调用去除括号的函数,进行下一步操作
print(ret)
2.更高级的计算器
import re
from functools import reduce
from tkinter import *
'''处理特殊-号运算'''
def minus_operation(expresstion):
minus_operators = re.split("-", expresstion)
calc_list = re.findall("[0-9]", expresstion)
if minus_operators[0] == "":
calc_list[0] = '-%s' % calc_list[0]
res = reduce(lambda x, y: float(x) - float(y), calc_list)
print(">>>>>>>>>>>>>>减号[%s]运算结果:" % expresstion, res)
return res
'''reduce()对sequence连续使用function, 如果不给出initial, 则第一次调用传递sequence的两个元素,
以后把前一次调用的结果和sequence的下一个元素传递给function'''
'''处理双运算符号'''
def del_duplicates(expresstion):
expresstion = expresstion.replace("++", "+")
expresstion = expresstion.replace("--", "-")
expresstion = expresstion.replace("+-", "-")
expresstion = expresstion.replace("--", "+")
expresstion = expresstion.replace('- -', "+")
return expresstion
'''*/运算函数'''
def mutiply_dividend(expresstion):
calc_list = re.split("[*/]", expresstion) # 用* or /分割公式
operators = re.findall("[*/]", expresstion) # 找出所有*和/号
res = None
for index, i in enumerate(calc_list):
if res:
if operators[index - 1] == '*':
res *= float(i)
elif operators[index - 1] == '/':
res /= float(i)
else:
res = float(i)
procession0 = "[%s]运算结果=" % expresstion, res
# final_result.insert(END, procession0) # 插入窗体
print(procession0)
return res
'''处理运算符号顺序混乱情况'''
def special_features(plus_and_minus_operators, multiply_and_dividend):
for index, i in enumerate(multiply_and_dividend):
i = i.strip()
if i.endswith("*") or i.endswith("/"):
multiply_and_dividend[index] = multiply_and_dividend[index] + plus_and_minus_operators[index] + multiply_and_dividend[index + 1]
del multiply_and_dividend[index + 1]
del plus_and_minus_operators[index]
return plus_and_minus_operators, multiply_and_dividend
def minus_special(operator_list, calc_list):
for index, i in enumerate(calc_list):
if i == '':
calc_list[index + 1] = i + calc_list[index + 1].strip()
'''运算除了()的公式+-*/'''
def figure_up(expresstion):
expresstion = expresstion.strip("()") # 去掉外面括号
expresstion = del_duplicates(expresstion) # 去掉重复+-号
plus_and_minus_operators = re.findall("[+-]", expresstion)
multiply_and_dividend = re.split("[+-]", expresstion)
if len(multiply_and_dividend[0].strip()) == 0:
multiply_and_dividend[1] = plus_and_minus_operators[0] + multiply_and_dividend[1]
del multiply_and_dividend[0]
del plus_and_minus_operators[0]
plus_and_minus_operators, multiply_and_dividend = special_features(plus_and_minus_operators, multiply_and_dividend)
for index, i in enumerate(multiply_and_dividend):
if re.search("[*/]", i):
sub_res = mutiply_dividend(i)
multiply_and_dividend[index] = sub_res
# print(multiply_and_dividend, plus_and_minus_operators) # 计算
final_res = None
for index, item in enumerate(multiply_and_dividend):
if final_res:
if plus_and_minus_operators[index - 1] == '+':
final_res += float(item)
elif plus_and_minus_operators[index - 1] == '-':
final_res -= float(item)
else:
final_res = float(item)
procession = '[%s]计算结果:' % expresstion, final_res
# final_result.insert(END, procession) # 插入窗体
# print(procession)
return final_res
"""主函数:运算逻辑:先计算拓号里的值,算出来后再算乘除,再算加减"""
def calculate():
expresstion = expresstions.get() # 获取输入框值
flage = True
calculate_res = None # 初始化计算结果为None
while flage:
m = re.search("\([^()]*\)", expresstion) # 先找最里层的()
# pattern = re.compile(r"\([^()]*\)")
# m = pattern.match(expresstion)
if m:
sub_res = figure_up(m.group()) # 运算()里的公式
expresstion = expresstion.replace(m.group(), str(sub_res)) # 运算完毕把结果替换掉公式
else:
# print('---------------括号已经计算完毕--------------')
procession1 = "最终计算结果:%s\n"%figure_up(expresstion)
print(procession1)
final_result.insert(END, procession1) # 插入窗体
# print('\033[31m最终计算结果:', figure_up(expresstion))
flage = False
if __name__ == "__main__":
# res = calculate("1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)/ (16-3*2) )")
window = Tk() ###创建窗体
window.title('计算器') ###命名窗体
frame1 = Frame(window) ###框架1
frame1.pack() ###放置
frame2 = Frame(window) ###框架2
frame2.pack() ###放置
lable = Label(frame1, text="请输入公式:") ###文字标签
lable.pack()
expresstions = StringVar() ###输入框属性,字符串
entryname = Entry(frame1, textvariable=expresstions) ###文本输入框
bt_get_expresstions = Button(frame1, text="提交", command=calculate) ###按钮挂件
bt_get_expresstions.pack()
entryname.pack()
lable.grid_slaves(row=1,column=1)
entryname.grid_slaves(row=1,column=1)
bt_get_expresstions.grid_slaves(row=1,column=3)
final_result = Text(frame2) ###计算结果显示框
final_result.tag_config("here", background="yellow", foreground="blue")
final_result.pack()
window.mainloop() ###事件循环
来源:http://www.cnblogs.com/haiyan123/p/7397457.html


猜你喜欢
- 在写一些很小的机器学习项目的时候,我们往往希望training, testing和inference能共用一个入口main,但是不同的功能使
- 项目中要对短文本进行相似度估计,word2vec是一个很火的工具。本文就word2vec的训练以及加载进行了总结。word2vec的原理就不
- 首先得明确包和模块。包:在一个目录下存在__init__.py,那么该目录就是一个包。模块:一个.py文件就是一个模块。我们可以通过from
- 案例解析这个问题描述起来有点违反直觉,要执行一个文件难道不应该需要可执行权限吗?让我们先来看一个例子:# module1.pydef tes
- WxPython界面用pubsub实现多线程控制用WxPython做界面时, 如果数据操作时间比较长,会使 WxPython 界面处于假死状
- 一、效果展示话不多说先上效果为了更有意境我加了个完美的背景来衬托出月饼的好看我的月饼画的不圆的原因是我故意的,为什么呢?因为月有阴晴圆缺啊!
- MySQL变量很多,其中有一些MySQL变量非常值得我们注意,下面就为您介绍一些值得我们重点学习的MySQL变量,供您参考。1 Thread
- 前言对于专业的python程序员来说,python打包工具或许用得并不多。但是对于非专业人士来说,你给他写个python项目,要让他安装py
- 本文为大家分享了pygame游戏之旅的第11篇,供大家参考,具体内容如下定义一个button函数,将文字,颜色等作为参数。def butto
- select UNIX_TIMESTAMP(ADDDATE(NOW(),INTERVAL -60 DAY))首先根据now()获得当前时间使
- 1.intersect为取多个查询结果的交集;2.查询两个基本时间段内表记录的SQL语句;select * from shengjibiao
- 演示:<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//
- Python提取html中文本到txt正则去标签方式# -*- coding: utf-8 -*-import redef html_tag
- 1、问题描述在项目开发中,当我们通过npm run build打包之后将文件放在服务器上时通常会出现图片失效问题,控制台中提示某个图片没有找
- 进入主题1.import turtle as timport matht.pensize(3)t.tracer(10)t.hideturtl
- 一、何为php PHP,即“PHP: Hypertext Preprocesso
- 子查询分类按返回结果集分类子查询按返回结果集的不同分为4种:表子查询,行子查询,列子查询和标量子查询。 表子查询:返回的结果集是一个行的集合
- 你已经在上面取出w打头记录的例子中看到了LIKE的用法。LIKE判定词是一个非常有用的符号。不过,在很多情况下用了它可能会带给你太多的数据,
- 带你了解CGO编程大学时最开始学的语言莫过于C/C++,C/C++经过几十年的发展,已经积累了庞大的软件资产,它们很多久经考验而且性能已经足
- 继续分享pygame有趣的技术知识,欢迎往下看。一、先搭个架子(一)黏贴背景图:实现代码如下:import pygamepygame.ini