# !/usr/bin/env python3
# _*_coding:utf-8_*_
'''
实现模拟计算器的功能:
公式: - * ( (- +(-/) * (-*/ + /*/* + * / )) - (-*)/ (-*) )
思路:
括号的计算优先级最高,应该优先计算括号内的式子,然后将值代替会原式子,循环,接着做惩处运算,最后是加减运算,然后弹出结果,
# print(eval('1-2*((60-30+(-40/5)*(9-2*5/3+7/3*99/4*2998+10*568/14))-(-4*3)/(16-3*2))'))
'''
import re symbol = ['', '', '', '', '', '', '', '', '', '', '-', '+', '*', '/', '(', ')'] def check(formula):
'''
检查输入的公式的正确性:
除了十个数字和六个符号,其他的一律判错,但是这样会限制运算规则,目前先是这样规划
:param formula:
:return:
'''
symbol_flag = True
formula = re.sub(r'\s*', '', formula)
cal_list = list(formula)
for item in cal_list:
if item not in symbol:
symbol_flag = False
if not symbol_flag:
return
else:
return formula def change(formula):
'''
替换出现两个运算符在一起的情况:
:param formula:
:return:
'''
formula = formula.replace('--', '+')
formula = formula.replace('++', '+')
formula = formula.replace('**', '*')
formula = formula.replace('//', '=')
formula = formula.replace('*+', '*')
formula = formula.replace('/+', '/')
return formula def chengchu(arg):
val = arg[]
match = re.search(r'\d+\.*\d*[\*\/]+[\+\-]?\d+\.*\d*', val)
if not match:
return content = re.search(r'\d+\.*\d*[\*\/]+[\+\-]?\d+\.*\d*', val).group()
if len(content.split('*')) > :
n1, n2 = content.split('*')
value = float(n1) * float(n2)
else:
n1, n2 = content.split('/')
value = float(n1) / float(n2) before, after = re.split(r'\d+\.*\d*[\*\/]+[\+\-]?\d+\.*\d*', val, )
new_str = '%s%s%s' % (before, value, after)
arg[] = new_str
print(arg)
chengchu(arg) def jiajian(arg):
while True:
if arg[].__contains__('+-') or arg[].__contains__("++") or arg[].__contains__('-+') or arg[].__contains__(
"--"):
arg[] = arg[].replace('++', '+')
arg[] = arg[].replace('+-', '-')
arg[] = arg[].replace('--', '+')
arg[] = arg[].replace('-+', '-')
else:
break if arg[].startswith('-'):
arg[] +=
arg[] = arg[].replace('-', '&')
arg[] = arg[].replace('+', '-')
arg[] = arg[].replace('&', '+')
arg[] = arg[][:] val = arg[] match = re.search(r'\d+\.?\d*[-+]{1}\d+\.?\d*', val)
if not match:
return content = re.search(r'\d+\.?\d*[-+]{1}\d+\.?\d*', val).group() if len(content.split('+')) > :
n1, n2 = content.split('+')
value = float(n1) + float(n2)
else:
n1, n2 = content.split('-')
value = float(n1) - float(n2) before, after = re.split(r'\d+\.?\d*[-+]{1}\d+\.?\d*', val, )
new_str = '%s%s%s' % (before, value, after)
arg[] = new_str
jiajian(arg) def compute(formula):
'''
操作加减乘除:根据操作
:param formula:
:return:
'''
inp = [formula, ] #
chengchu(inp)
jiajian(inp)
if divmod(inp[], )[] == :
result = float(inp[])
result = float(result) * -
else:
result = float(inp[])
return result def calcultor(formula):
'''
递归处理括号,并计算括号内的式子,将结果返回做替换,
:param formula:
:return:
'''
# 没有括号了
if not re.search(r'\(([-+*/]*\d+\.*\d*){2,}\)', formula):
final = compute(formula)
return final
# 取出其中的一个括号,然后计算
content = re.search(r'\(([-+*/]*\d\.*\d*){2,}\)', formula).group()
# 分裂表达式
before, nothing, after = re.split(r'\(([-+*/]*\d+\.*\d*){2,}\)', formula, )
# 计算括号里的内容
content = content[:len(content) - ]
ret = compute(content)
# 计算完后然后拿到结果,然后重新拼接成一个新的式子
formula = '%s%s%s' % (before, ret, after)
return calcultor(formula) # s='1-2*((60-30+(-40/5)*(9-2*5/3+7/3*99/4*2998+10*568/14))-(-4*3)/(16-3*2))'
# calcultor(s) def main():
print('欢迎使用计算器'.center(, '#'))
while True:
formula = input('计算式>>:').strip()
if formula == 'q':
exit()
elif len(formula) == :
continue
else:
formula=check(formula)
if formula == :
continue
else:
result = calcultor(formula)
print('计算结果为:\033[1;31;1m %s\033[0m' % (result))
try:
print('正确答案是:\033[1;31;1m %s\033[0m' %(eval(formula)))
except:
print('无法计算') if __name__ == '__main__':
main()

作业五:RE 模块模拟计算器的更多相关文章

  1. python作业模拟计算器开发(第五周)

    作业需求: 模拟计算器开发: 实现加减乘除及拓号优先级解析 用户输入 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/1 ...

  2. nodejs爬虫笔记(五)---利用nightmare模拟点击下一页

    目标 以腾讯滚动新闻为例,利用nightmare模拟点击下一页,爬取所有页面的信息.首先得感谢node社区godghdai的帮助,开始接触不太熟悉nightmare,感觉很高大上,自己写代码的时候问题 ...

  3. C#基础第三天-作业答案-集合-冒泡排序-模拟名片

    .冒泡排序 Console.WriteLine("对集合里的数进行排序,请输入第一个数:"); int a = int.Parse(Console.ReadLine()); Con ...

  4. 烟大 Contest1024 - 《挑战编程》第一章:入门 Problem D: LC-Display(模拟计算器显示数字)

    Problem D: LC-Display Time Limit: 1 Sec  Memory Limit: 64 MBSubmit: 14  Solved: 3[Submit][Status][We ...

  5. 基于visual Studio2013解决C语言竞赛题之1088模拟计算器

        题目 解决代码及点评 /************************************************************************/ /* ...

  6. python爬虫主要就是五个模块:爬虫启动入口模块,URL管理器存放已经爬虫的URL和待爬虫URL列表,html下载器,html解析器,html输出器 同时可以掌握到urllib2的使用、bs4(BeautifulSoup)页面解析器、re正则表达式、urlparse、python基础知识回顾(set集合操作)等相关内容。

    本次python爬虫百步百科,里面详细分析了爬虫的步骤,对每一步代码都有详细的注释说明,可通过本案例掌握python爬虫的特点: 1.爬虫调度入口(crawler_main.py) # coding: ...

  7. jQuery系列:五个模块总结

    Query插件,以备并希望在前端方面有所长进.请批评指正. 一,类型判断全解 JQuery判断类型扩展方法:$.type() /*type: function( obj ) { if ( obj == ...

  8. Python 第五天 递归,计算器(2)

    利用函数编写如下数列: 斐波那契数列指的是这样一个数列 0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233,377,610,987,1597,2584, ...

  9. 从零开始学Python04作业源码:模拟ATM电子银行(仅供参考)

    bin目录:程序启动入口 ATM_start.py: #!/usr/bin/python # -*- coding: utf-8 -*- # 模拟ATM电子银行+登录账户权限控制+管理员管理模块 # ...

随机推荐

  1. IE浏览器右键菜单插件开发(上篇)——自定义一个IE右键菜单项

    要做一个IE右键浏览器插件,得3步走. 第一,在IE右键菜单上添加自定义菜单名称,是通过注册表实现的,如下: string regkey = @"Software\Microsoft\Int ...

  2. Hadoop2.x 体系结构和源码编译

    体系结构 Hadoop1的核心组成包括HDFS和MapReduce.HDFS和MapReduce的共同点就是他们都是分布式的. HDFS是包括主节点NameNode,只有一个,还有很多从节点DataN ...

  3. python计算机基础-Day1

    计算机基础-Day1 一.计算机基础 首先Python是一门编程语言 语言: 那什么是语言?语言就是一种事物与另一种事物沟通的介质. 所以说编程语言是程序员跟计算机沟通的介质,那么为什么要跟计算机沟通 ...

  4. 如何关闭常见浏览器的 HSTS 功能

    在安装配置 SSL 证书时,可以使用一种能使数据传输更加安全的Web安全协议,即在服务器端上开启HSTS (HTTP Strict Transport Security).它告诉浏览器只能通过HTTP ...

  5. c++趣味之为变参模板的每个参数执行单独函数

    对于c++11以后出现的可变参数模板,一般我们都统一处理所有的参数.而当需要为每个参数执行不同的操作或调用不同的函数时,语法上是没有直接支持的. 可变参数的模板语法: template<type ...

  6. Go基础之锁的初识

    当我们的程序就一个线程的时候是不需要用到锁的,但是通常我们实际的代码不会是单个线程的,所有这个时候就需要用到锁了,那么关于锁的使用场景主要涉及到哪些呢? 当我们多个线程在读相同的数据的时候则是需要加锁 ...

  7. spring boot高性能实现二维码扫码登录(上)——单服务器版

    前言 目前网页的主流登录方式是通过手机扫码二维码登录.我看了网上很多关于扫码登录博客后,发现基本思路大致是:打开网页,生成uuid,然后长连接请求后端并等待登录认证相应结果,而后端每个几百毫秒会循环查 ...

  8. protobuf的下载、编译和使用

    一 背景 工作中临时需要使用 protobuf v3.0.2 做消息格式转换,折腾了很久才搞定,这里特意做一个记录. 二 准备工作 全程使用的电脑为公司的win7 64位旗舰版,已经预先安装VS201 ...

  9. Mycat 分片规则详解--取模分片

    实现方式:切分规则根据配置中输入的数值n.此种分片规则将数据分成n份(通常dn节点也为n),从而将数据均匀的分布于各节点上. 优点:这种策略可以很好的分散数据库写的压力.比较适合于单点查询的情景 缺点 ...

  10. 【Zabbix】 Zabbix表结构说明【转载】

    本文转自[https://www.cnblogs.com/shhnwangjian/p/5484352.html] 参考文[https://www.cnblogs.com/learningJAVA/p ...