带括号的计算器也是第一个自我感觉完成最好的 毕竟真的弄了一个多星期 虽然前期这路真的很难走  我会努力加油  将Python学好学踏实

参考了两位博主的文章

http://www.cnblogs.com/0zcl/p/5983236.html

http://www.cnblogs.com/loyfee/p/5764926.html#3538071

大致过程就是 先将输入的数据转为列表 当中去除空字符  

接着找出最里层括号 进行运算 再将结果放回列表 最后算出结果

import re
#data = input("请输入算术:") def change_list(data):
data =re.sub(" ","",data)#将空格转为""
# print(data)
data_list = []
for i in data:
data_list.append(i)
num =
try:
while :
if data_list[] == "-":
data_list[] = data_list[] + data_list[]
data_list.pop()
if data_list[num].isnumeric():
if data_list[num+].isnumeric():
data_list[num] = data_list[num]+data_list[num+]
data_list.pop(num+)
else:
num +=
else:
num +=
except IndexError as e:
#print(e,"索引越界")
return data_list
# if data_list.index(data_list[-]) <num:
# print(data_list)
# break def compute(data):
while :
#判断乘除
if "*" in data or "/" in data:
for i,j in enumerate(data):
if j == "*":
data[i+] =int(data[i-]) * int(data[i+])
data.pop(i-)
data.pop(i-)
break
if j == "/":
data[i+] =int(data[i-]) * int(data[i+])
data.pop(i-)
data.pop(i-)
break
#判断加减
if "+" in data or "-" in data:
for i,j in enumerate(data):
if j == "+":
data[i + ] = int(data[i - ]) + int(data[i + ])
data.pop(i - )
data.pop(i - )
break
if j == "-":
data[i + ] = int(data[i - ]) - int(data[i + ])
data.pop(i - )
data.pop(i - )
break
else:
return data
break #有括号和无括号运算
"""
如果有括号 则会以最里层的“)”去找到与其第一个“(” 用:截取中间的数字进行运算,接着传回列表
直到没有括号时跳出 进行运算
"""
def parenth(data):
if "(" in data:
while :
if ")" in data:
b = data.index(")")#表示第一个“)”的索引位置
#print(b)
for i in range(b,-,-): #截取最里层括号进行运算
#print(i) if data[i] == "(":
new_list = []
new_list=data[i+:b]
byte=compute(new_list)[]
del(data[i:b+])
data.insert(i,byte)
break
else:
return compute(data) else:
compute(data)
while :
data = input("请输入计算:")
if data == "":continue
data = change_list(data)
parenth(data)
print(data[])
if input("如果输入q则退出:\n") == "q":
exit()

Python带括号的计算器的更多相关文章

  1. python函数带不带括号的问题

    Python带括号返回的是该函数的返回值 不带括号返回的是该函数的位置信息等

  2. 使用python开发一个能够计算带括号的复杂表达式的计算器(只支持加减乘除)

    使用到了模块re,正则,字典等 # 实现简单的加减乘除括号等运算 # Calculator def calculator(expression): print(expression) import r ...

  3. Python中类-带括号与不带括号的区别

    类不带括号我们叫赋值,带括号我们叫实例化. 什么是赋值? a=7 b=a id(7) 140726814208448 id(a) 140726814208448 id(b) 1407268142084 ...

  4. Python调用函数带括号和不带括号的区别

    1.不带括号时,调用的是这个函数本身 ,是整个函数体,是一个函数对象,不需等该函数执行完成 2.带括号(此时必须传入需要的参数),调用的是函数的return结果,需要等待函数执行完成的结果 如果函数本 ...

  5. python装饰器带括号和不带括号的语法和用法

    装饰器的写法补充: 通常装饰器的写法是@func(),而有的时候为了减少出错率,可能会写成@func,没有()括号,这时我们可以这样定义,来减少括号.下面通过两个例子还看. 一般装饰器的写法: def ...

  6. Python笔记:调用函数,带扩号和和不带括号的区别

    调用函数,如果带括号,那么是调用函数运行后的结果, 调用函数不带括号,调用的是函数本身 例如: def cun (a,b): return a+b print(cun) : 调用函数,打印的是函数 p ...

  7. 教学项目之-通过Python实现简单的计算器

    教学项目之-通过Python实现简单的计算器   计算器开发需求 实现加减乘除及拓号优先级解析 用户输入 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/ ...

  8. python实现简单的计算器功能

    如想实现一个计算器的功能,输入格式为字符串,不能运用python里面的内置方法,出去简单的加减乘除,设计一个相对高级的计算器: a = '1 - 2 * ( ( 6 0 -3 0 +(-40/5) * ...

  9. python正则实现简单计算器

    利用正则实现计算器 利用正则来实现简单计算器的功能,能够设计计算带括号的加减乘除运算.当然不使用eval等语句. 利用递归: import re from functools import reduc ...

随机推荐

  1. [洛谷P1920]成功密码

    题目大意:给你n和x($n\leq 10^{18},0<x\leq 1$),要你求$\sum_{i=1}^n\frac{x^i}{i}$. 解题思路:首先n大到要用long long存,暴力肯定 ...

  2. 一句话木马和中国菜刀的结合拿webshell

    什么叫做一句话木马:     就是一句简单的脚本语言,一句话木马分为Php,asp,aspx等 中国菜刀:   连接一句话木马的工具 实验的目的:  通过一句话木马来控制我们的服务器,拿到webshe ...

  3. eclipse/myeclipse中js/java的自动提示只有4个字符怎么解决

    https://blog.csdn.net/LinBM123/article/details/80450690

  4. 洛谷 P1373 小a和uim之大逃离 (差值型dp总结)

    这道题和多米诺骨牌那道题很像 ,都是涉及到差值的问题. 这道题是二维的,同时要取模. 这种题,因为当前的决策有后效性,会影响到差值,所以直接把 差值作为维度,然后计算答案的时候把差值为0的加起来就行了 ...

  5. Oracle中set serveroutput on介绍

    定义 set serveroutpu on是使oracle可以使用自带的输出方法 dbms_output.put_line('XX'); 使用范围 使用于PL/SQL COMMAND WINDOW,S ...

  6. V$ASM_OPERATION

  7. bzoj1002: [FJOI2007]轮状病毒(基尔霍夫矩阵)

    1002: [FJOI2007]轮状病毒 题目:传送门 题解: 决定开始板刷的第一题... 看到这题的时候想:这不就是求有多少种最小生成树的方式吗? 不会啊!!!%题解... 什么鬼?基尔霍夫矩阵?? ...

  8. 34.angularJS的{{}}和ng-bind

    转自:https://www.cnblogs.com/best/tag/Angular/ 1. <html> <head> <meta charset="utf ...

  9. PHP万能的连接数据库

    <?php class DB{ const HOST='127.0.0.1'; const USER='root'; const PASS='root'; const DATA='mooc'; ...

  10. PostgreSQL Replication之第七章 理解Linux高可用(2)

    7.2 衡量可用性 可用性是提供商试图保证一定的可用性级别和客户可以期望的可用性或更多.在某些情况下(取决于服务合同) 收取罚款或减少申购费用是意外停机的原因. 可用性的质量使用百分数来衡量:例如,9 ...