python第二十一天---昨天没写完作业
作业 2, 模拟计算器开发:
实现加减乘除及拓号优先级解析
用户输入 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)/ (16-3*2) )等类似公式后,必须自己解析里面的(),+,-,*,/符号和公式(不能调用eval等类似功能偷懒实现),运算后得出结果,结果必须与真实的计算器所得出的结果一致 2776672.6952380957
流程图:

详细代码:
#!usr/bin/env python
#-*-coding:utf-8-*-
# Author calmyan
import re
#b='1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)/ (16-3*2) )'
#b='1 - 2 * ( (60-30 +(-40/5) * (9-2**5//3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)// (16-3*2) )'
#print(b) def list_format(b):#格式化字符串函数
b=re.sub(' ','',b)
b=[i for i in re.split('(\-?\d+\.*\d*)',b) if i]#循环判断,i 不为空,添加到列表 去空字符 -开头加后面的数字
#print(b)
tmp_list=[]#定义一个临时列表
while True:
if len(b)==0:break#如果列表为空就退出
emp=b.pop(0)#取出第一个元素
if (len(tmp_list)==0 and re.search('^\-\d*$',emp)) or (len(tmp_list)>0 and re.search('[\+\-\*\/\(\)]$',tmp_list[-1]) ):#判断开头与中间的负数
tmp_list.append(emp)
continue
sny_nl=[i for i in re.split('([\+\-\*\/\(\)])',emp) if i]#对运算符进行分割 for index, i in enumerate(sny_nl):
if i==' ':#去空格判断
sny_nl.pop(index)#删除空格项
tmp_list+=sny_nl return tmp_list#返回列表 def Prioty(str_n,i):#比较优先级函数
lev1=['+','-']
lev2=['*','/']
lev3=['(']
lev4=[')']
if str_n in lev1:
if i in lev2 or i in lev3:#如果str_n 为+ - i 在2,3级时返回小于
return 1
else:
return 3
elif str_n in lev2:#如果str_n 为*/ i 在3级时返回小于
if i in lev3:
return 1
else:
return 3
elif str_n in lev3:#如果str_n 为(i 在4级时返回等于
if i in lev4:
return 2
else:
return 1 def sny(str):#判断是否为运算符
sny_l=['+','-','*','/','**','//','(',')']
tag=False
if str in sny_l:
return True#是运算符返回真
else:
return tag def opera(num1,operation,num2):#运算函数
res=0
if operation=='+':
res=num1+num2
if operation=='-':
res=num1-num2
if operation=='*':
res=num1*num2
if operation=='/':
res=num1/num2
return res def main(c):#主函数
numbe_list=[]#定义数字堆栈
sny_list=[]#定义运算符堆栈
for i in c:
if sny(i):#不是运算运
while True:
#print(numbe_list)
#print(sny_list)
if len(sny_list)==0:#如果列表为空,即第一个就无条件加入
sny_list.append(i)
break
prty=Prioty(sny_list[-1],i)#
if prty==1:#如果为一级
sny_list.append(i)#运算符继续添加
break
elif prty==2:#如果为二级
sny_list.pop()#运算符要取出最后一个
break
elif prty==3:#如果为三级
operation=sny_list.pop()#运算符==取出最后一个
num2=numbe_list.pop()#取出数字二
num1=numbe_list.pop()#取出数字一
numbe_list.append(opera(num1,operation,num2))#数字列表添加运算的结果
#print(numbe_list,sny_list)
continue
else:
i = float(i)#转为浮点数
numbe_list.append(i)#添加到数字列表
else:
operation=sny_list.pop()#运算符==取出最后一个
num2=numbe_list.pop()#取出数字二
num1=numbe_list.pop()#取出数字一
numbe_list.append(opera(num1,operation,num2))#数字列表添加运算的结果
#print(numbe_list,sny_list)
if len(sny_list):#如果运算符列表不为空再做一个运算
operation=sny_list.pop()#运算符==取出最后一个
num2=numbe_list.pop()#取出数字二
num1=numbe_list.pop()#取出数字一
numbe_list.append(opera(num1,operation,num2))#数字列表添加运算的结果
return numbe_list[0] #程序开始
print("\033[35;1m欢迎使用python简易计算器\033[0m".center(60,'='))
if __name__ =='__main__':
while True:
b=input('请输入你要计算的内容,按\033[31;1mQ/q\033[0m退出:')
if b=='q' or b=='Q':
exit()
#print(c)
try:
c=list_format(b)#运行输入函数格式化字符串,存入列表
number=main(c)
print(number)
except Exception as e:#出错可返回操作
print('输入有误,请重新输入')
python第二十一天---昨天没写完作业的更多相关文章
- Word 双栏排版最后多一页空白页删不掉、左栏文字没写完就到右栏了
1. 问题 问题:Word双栏排版,最后多一页空白页,删不掉.如图: 原因分析:删不掉是因为末尾文字处其实有个下一页分节符,只不过可能看不到. 如何清晰的看到? 视图 > 大纲,就可以看到了.如 ...
- XObject.java 对象还没写完,希望电脑不会丢失。坏笑,早点见。
/*面向对象强调的是对象, 面向过程强调的是功能行为,打开行为,关闭行为,执行行为,把多个行为封装成对象执行更强大的功能就是面向对象,是把多个函数, 多 个行为封装在一起,单一的函数执行对象的功能太困 ...
- 【Luogu】【关卡2-7】深度优先搜索(2017年10月)【AK】【题解没写完】
任务说明:搜索可以穷举各种情况.很多题目都可以用搜索完成.就算不能,搜索也是骗分神器. P1219 八皇后 直接dfs.对角线怎么判断:同一条对角线的横纵坐标的和或者差相同. #include < ...
- python Web抓取(一)[没写完]
需要的模块: python web抓取通过: webbrowser:是python自带的,打开浏览器获取指定页面 requests:从因特网上下载文件和网页 Beautiful Soup:解析HTML ...
- QBXT Day2主要是数据结构(没写完先占坑)
简单数据结构 本节课可能用到的一些复杂度: O(log n). 1/1+1/1/.....1/N+O(n log n) 在我们初学OI的时候,总会遇到这么一道题. 给出N次操作,每次加入一个数,或者询 ...
- D5(太长了md没写完)
动态规划 三种常见实现方法 对于一个斐波那契数列,我们想要求第n项的值,就需要一项一项的递归来求 来看代码 f[o] = 0; f[1] = 1; for (int i = 2; i <= n; ...
- 前端性能测试工具 : dynaTrace Ajax (还没写完)
今天开始写这个工具, #什么是dynaTrace Ajax? 随着 jQuery.Dojo.YUI 等框架的兴起让构建 Web2.0 应用更加容易,但随之带来的定位等应用问题也越来越难,尤其是与性能相 ...
- D3(没写完
说在博客前 这篇博客有许多使用到 STL 的地方,由于本人实在是记不全,所以我也参考了北大的一些教材,就别说我黈力了 QwQ 数据结构 今天讲的是数据结构啦(也是我这个蒟蒻最喜欢的 一些天天见面的好盆 ...
- mock的使用及取消,node模仿本地请求:为了解决前后端分离,用户后台没写完接口的情况下
借鉴:https://www.jianshu.com/p/dd23a6547114 1.说到这里还有一种是配置node模拟本地请求 (1)node模拟本地请求: 补充一下 [1]首先在根目录下建一个d ...
随机推荐
- [源码]Delphi源码免杀之函数动态调用 实现免杀的下载者
[免杀]Delphi源码免杀之函数动态调用 实现免杀的下载者 2013-12-30 23:44:21 来源:K8拉登哥哥's Blog 自己编译这份代码看看 过N多杀软 没什么技 ...
- Appium+Python 自动化-appium常用元素定位方法
https://www.cnblogs.com/rabbit-testing/p/8042733.html 大牛 https://blog.csdn.net/kaka1121/article/deta ...
- 动态生成二维码并利用canvas合成出一张图片(类似海报、分享页)
在前端开发并打算推广一个APP的时候,推广页是免不了的,而推广页的展示方式一般是给人家一个二维码,让别人自己去安装APP,这样前段任务也达到了,这次写这篇文章的原因主要还是总结一下,其中有很多不完善的 ...
- Springboot+Thymeleaf+layui框架的配置与使用
前言Springboot默认是不支持JSP的,默认使用thymeleaf模板引擎.所以这里介绍一下Springboot使用Thymeleaf的实例以及遇到的问题. 配置与使用1.在applicatio ...
- Nexus安装、使用说明 (转)
1. 为什么使用Nexus 如果没有私服,我们所需的所有构件都需要通过maven的中央仓库和第三方的Maven仓库下载到本地,而一个团队中的所有人都重复的从maven仓库下 载构件无疑加大了仓库的负载 ...
- zabbix 自定义监控项简单案例
例如:获取被监控主机的登录用户数 以uptime为例: 输入命令:uptime | awk '{print $6}' 可以获得当前登录用户数(不通终端打印出的位置不同) 1.被监控主机修改zabbi ...
- ADNI数据
之前整理的数据相关内容 数据的模态有 Clinical Data(临床数据) Genetic(基因数据) MRI PET BIOSPECIMEN(生物样本) 各模态数据的内容.特点 Clinical ...
- python装饰器带括号和不带括号的语法和用法
装饰器的写法补充: 通常装饰器的写法是@func(),而有的时候为了减少出错率,可能会写成@func,没有()括号,这时我们可以这样定义,来减少括号.下面通过两个例子还看. 一般装饰器的写法: def ...
- .12-浅析webpack源码之NodeWatchFileSystem模块总览
剩下一个watch模块,这个模块比较深,先大概过一下整体涉及内容再分部讲解. 流程图如下: NodeWatchFileSystem const Watchpack = require("wa ...
- ASP.NET Web API 启用跨域访问
自定义特性 要在WebApi中实现JSONP,一种方式是实现自定义特性 http://stackoverflow.com/questions/9421312/jsonp-with-asp-net-w ...