s12-day04-work01 简单计算器功能实现
代码:
#!/usr/local/env python3
'''
Author:@南非波波
Blog:http://www.cnblogs.com/songqingbo/
E-mail:qingbo.song@gmail.com
''' import time,sys
import module if __name__ == "__main__":
while True:
count = 0
if count < 3:
print('''
请输入一个计算公式,类似下面格式:
=========================================================================================
1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)/ (16-3*2) )
=========================================================================================
系统默认匹配所有的数字、(、)、+、-、/、*、.
计算器程序研发@南非波波
''')
expression = input("请输入:").strip() #或取用户输入的表达式字符串,并去除左右的空格
# expression = "1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)/ (16-3*2) )"
expression = expression.replace(' ','') #去除字符串中间的空格,使用replace进行空字符串替换空格
if module.num_operator(expression): #成功匹配正确表达式
# print(expression)
result = module.recursion_bracket(expression) #将处理后没有括号的表达式赋值给expression
print(result)
break
else:
count += 1
print("你输入的表达式格式不正确!")
time.sleep(1)
continue
else:
print("你的输入错误次数已达三次,计算器将自动退出!感谢你的使用!")
time.sleep(1)
sys.exit(3)
index.py
#!/usr/local/env python3
'''
Author:@南非波波
Blog:http://www.cnblogs.com/songqingbo/
E-mail:qingbo.song@gmail.com
''' import re #匹配一个表达式中的数字和运算符,如果匹配,返回expression,否则返回None
def num_operator(expression):
match_list = re.findall("[0-9]|\(|\)|\+|\-|\*|\/|.",expression)
if len(expression) == len(match_list):
return True #特殊字符处理
def charmap(expression):
flag = True
while flag:
if expression.__contains__("++") or expression.__contains__("+-") or expression.__contains__("-+") or expression.__contains__("--"):
# match_str = re.search("\d+\.*\d*(\+\-){1}\d+\.*\d*",expression).group()
expression = expression.replace('+-','-')
expression = expression.replace('++','+')
expression = expression.replace('-+','-')
expression = expression.replace('--','+')
else:
flag = False
return expression
#操作加减
def compute_add_sub(expression):
'''
expression表达式传进来的形式是(5+1-4),左右成一对括号。所以这里需要将括号去掉
'''
expression = expression.lstrip('(').rstrip(')') #去除表达式左右的括号
match_test = re.search("\d+\.*\d*[\+\-]{1}\d+\.*\d*",expression)
if not match_test:
return expression
else:
match_str = match_test.group()
if len(match_str.split('+')) > 1:
num1,num2 = match_str.split("+")
result = float(num1) + float(num2)
else:
num1,num2 = match_str.split("-")
result = float(num1) - float(num2)
exp_join = expression.split(match_str)
expression = "%s%s%s" % (exp_join[0],result,exp_join[1])
return compute_add_sub(expression) #操作乘除
def compute_mul_div(expression):
'''
expression表达式传进来的形式是(9-2*5/3+7/3*99/4*2998+10*568/14),左右成一对的括号。所以这里就需要将括号去掉然后递归处理乘除
'''
expression = expression.lstrip('(').rstrip(')') #去除表达式左右的括号
match_test = re.search("\d+\.*\d*[\*\/]+[\+\-]?\d+\.*\d*",expression)
if not match_test: #判断是否能够匹配到* 或者 /。
return expression
else:
match_str = match_test.group() #获取到匹配的运算式,比如5/3,2*5
if len(match_str.split("/")) > 1: #计算除法
num1,num2 = match_str.split("/")
result = float(num1) / float(num2)
else: #计算乘法 len(match_str.split("*")) > 1
num1,num2 = match_str.split("*")
result = float(num1) * float(num2)
exp_join = expression.split(match_str)
expression = "%s%s%s" % (exp_join[0],result,exp_join[1])
compute_mul_div(expression) #递归处理
return compute_mul_div(expression) #处理优先级的执行
def compute_pri(expression):
expression = compute_mul_div(expression) #处理乘除
expression = charmap(expression) #处理特殊字符
expression = compute_add_sub(expression) #处理加减
return expression #返回一个值 #递归处理括号
def recursion_bracket(expression):
match_list = re.findall("\(|\)",expression) #匹配括号,如果存在递归处理
if not match_list:
# print(expression)
return compute_pri(expression)
else:
match_str = re.search("\([^()]*\)",expression) #匹配第一次出现的括号对
if match_str:
match_str = match_str.group()
# print("match_str:",match_str)
tmp = compute_pri(match_str)
expression = "%s%s%s" % (expression.split(match_str)[0],tmp,expression.split(match_str)[1]) #字符串拼接
# print("expression:",expression)
return recursion_bracket(expression) #递归处理括号 # expression = "(9-2*5/3+7/3*99/4*2998+10*568/14)"
# res = compute_pri(expression)
# print(res)
#递归处理括号
# def recursion_bracket(expression):
# match_list = re.findall("\(|\)",expression) #匹配括号,如果存在递归处理
# if match_list:
# tmp_list = [] #定义一个列表,存储左括号(
# res = ''
# for i in range(0, len(expression)):
# if expression[i] == "(":
# tmp_list.append(i) #获取括号出现的索引值列表
# print("tmp_list:",tmp_list)
# continue
# if expression[i] == ")" and tmp_list:
# ts = expression[tmp_list[-1]: i+1]
# if len(ts) > len(res):
# # ts = compute_mul_div(ts)
# # print(ts)
# # ts = charmap(ts)
# # ts = compute_add_sub(ts)
# res = ts
# print('i:%s,ts:%s' % (i,ts))
# tmp_list.pop()
# print(tmp_list)
# print("res:",res)
# # return recursion_bracket(res)
#
# else: #匹配括号失败,返回表达式,做后续处理
# expression = compute_mul_div(expression)
# expression = charmap(expression)
# expression = compute_add_sub(expression)
module.py
github代码更新地址:https://github.com/swht/projects/tree/master/day04/计算器
s12-day04-work01 简单计算器功能实现的更多相关文章
- java实现简单计算器功能
童鞋们,是不是有使用计算器的时候,还要进入运行,输入calc,太麻烦了,有时候甚至还忘记单词怎么拼写,呵呵程序员自己写代码实现,又简单,又方便啊 以下为代码(想要生成可执行工具可参考:http://w ...
- Android-Kotlin简单计算器功能
上一篇博客 Android-Kotlin-配置/入门 配置好了 AndroidStudio Kotlin 的环境: 选择包名,然后右键: 选择Class类型,会有class: 创建CounterCla ...
- Python之实现简单计算器功能
一,需求分析 要求计算一串包含数字+-*/()的类似于3*( 4+ 50 )-(( 100 + 40 )*5/2- 3*2* 2/4+9)*((( 3 + 4)-4)-4)表达式的数值 二,知识点 正 ...
- 简单计算器 安卓 Android 作业
Android老师布置的课程作业——简单计算器 功能要求实现四则运算,参考界面见下图: 首先给各位老铁提供apk安装包以及项目压缩包,略表诚意~ github地址:https://github.com ...
- 完成一段简单的Python程序,用于实现一个简单的加减乘除计算器功能
#!/bin/usr/env python#coding=utf-8'''完成一段简单的Python程序,用于实现一个简单的加减乘除计算器功能'''try: a=int(raw_input(" ...
- JS事件 编程练习-自制计算器 使用JS完成一个简单的计算器功能。实现2个输入框中输入整数后,点击第三个输入框能给出2个整数的加减乘除。
编程练习 使用JS完成一个简单的计算器功能.实现2个输入框中输入整数后,点击第三个输入框能给出2个整数的加减乘除. 提示:获取元素的值设置和获取方法为:例:赋值:document.getElement ...
- 【IOS开发笔记03-视图相关】简单计算器的实现
UIView 经过前几天的快速学习,我们初步了解的IOS开发的一些知识,中间因为拉的太急,忽略了很多基础知识点,这些知识点单独拿出来学习太过枯燥,我们在今后的项目中再逐步补齐,今天我们来学习APP视图 ...
- 菜鸟学Android编程——简单计算器《一》
菜鸟瞎搞,高手莫进 本人菜鸟一枚,最近在学Android编程,网上看了一些视频教程,于是想着平时手机上的计算器应该很简单,自己何不尝试着做一个呢? 于是就冒冒失失的开撸了. 简单计算器嘛,功能当然很少 ...
- javaWeb 使用 jsp 和 javaBean 实现计算器功能
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"% ...
随机推荐
- Hibernate持久化对象修改id重新保存的办法
Hibernate持久化对象修改id重新保存的办法——Hibernate学习记录二 2017年11月10日 20:16:48 筱光 阅读数:1122 版权声明:本文为博主原创文章,未经博主允许不得 ...
- libuv移植到ios
libuv官网只提供了os x的编译方法,没有IOS的.既然os x和ios的系统内核差不多,并且编译工具都是xcode,那我们只要重新指定cpu架构,就可以编译出ios版的了. 1.安装python ...
- OpenCV---圆检测
推文:Opencv2.4.9源码分析——HoughCircles 霍夫圆检测 加载一幅图像并对其模糊化以降噪 对模糊化后的图像执行霍夫圆变换 . 在窗体中显示检测到的圆. def detect_cir ...
- WebAPI IE8、IE9 跨域问题
关于WebAPI跨域的问题,网上已经很多了,以下方案可以解决很多跨域问题,但是都不支持IE8.IE9浏览器,JSONP也只能支持Get请求 通过dll配置 Install-Package Micros ...
- Codechef Dynamic Trees and Queries
Home » Practice(Hard) » Dynamic Trees and Queries Problem Code: ANUDTQSubmit https://www.codechef.co ...
- C++设计实现算法时易犯错误
1.未初始化 指针未初始化为NULL,造成判断条件出错 数值未初始化为0,造成数组超界,内存泄漏 2. long long输入时 lld or I64d 写成d一定出错 3.gcc编译报错:程序中有游 ...
- 《JavaScript 实战》:Tween 算法及缓动效果
Flash 做动画时会用到 Tween 类,利用它可以做很多动画效果,例如缓动.弹簧等等.我这里要教大家的是怎么利用 Flash 的 Tween 类的算法,来做js的Tween算法,并利用它做一些简单 ...
- ASP.NET 3.5控件和组件开发技术之客户端回发/回调揭密
本文摘录自<纵向切入ASP.NET 3.5控件和组件开发技术>. 对于服务端控件元素,比如ASP.NET的Button标准服务端控件在提交时可以自动把请求发送到服务端处理,这样的控件我们不 ...
- 说说ASP.NET的IsPostBack
学习asp.net,就不能不谈IsPostBack属性,顾名思义,这是是否回发的意思,多用于判断是不是第一次打开 一.IsPostBack介绍 Page.IsPostBack是一个标志:当前请求是否第 ...
- 【转】E: Sub-process /usr/bin/dpkg returned an error code (1)
原链接: jaryWang:E: Sub-process /usr/bin/dpkg returned an error code (1)错误解决 1.$ sudo mv /var/lib/dpkg/ ...