作业五:RE 模块模拟计算器
# !/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 模块模拟计算器的更多相关文章
- python作业模拟计算器开发(第五周)
作业需求: 模拟计算器开发: 实现加减乘除及拓号优先级解析 用户输入 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/1 ...
- nodejs爬虫笔记(五)---利用nightmare模拟点击下一页
目标 以腾讯滚动新闻为例,利用nightmare模拟点击下一页,爬取所有页面的信息.首先得感谢node社区godghdai的帮助,开始接触不太熟悉nightmare,感觉很高大上,自己写代码的时候问题 ...
- C#基础第三天-作业答案-集合-冒泡排序-模拟名片
.冒泡排序 Console.WriteLine("对集合里的数进行排序,请输入第一个数:"); int a = int.Parse(Console.ReadLine()); Con ...
- 烟大 Contest1024 - 《挑战编程》第一章:入门 Problem D: LC-Display(模拟计算器显示数字)
Problem D: LC-Display Time Limit: 1 Sec Memory Limit: 64 MBSubmit: 14 Solved: 3[Submit][Status][We ...
- 基于visual Studio2013解决C语言竞赛题之1088模拟计算器
题目 解决代码及点评 /************************************************************************/ /* ...
- python爬虫主要就是五个模块:爬虫启动入口模块,URL管理器存放已经爬虫的URL和待爬虫URL列表,html下载器,html解析器,html输出器 同时可以掌握到urllib2的使用、bs4(BeautifulSoup)页面解析器、re正则表达式、urlparse、python基础知识回顾(set集合操作)等相关内容。
本次python爬虫百步百科,里面详细分析了爬虫的步骤,对每一步代码都有详细的注释说明,可通过本案例掌握python爬虫的特点: 1.爬虫调度入口(crawler_main.py) # coding: ...
- jQuery系列:五个模块总结
Query插件,以备并希望在前端方面有所长进.请批评指正. 一,类型判断全解 JQuery判断类型扩展方法:$.type() /*type: function( obj ) { if ( obj == ...
- Python 第五天 递归,计算器(2)
利用函数编写如下数列: 斐波那契数列指的是这样一个数列 0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233,377,610,987,1597,2584, ...
- 从零开始学Python04作业源码:模拟ATM电子银行(仅供参考)
bin目录:程序启动入口 ATM_start.py: #!/usr/bin/python # -*- coding: utf-8 -*- # 模拟ATM电子银行+登录账户权限控制+管理员管理模块 # ...
随机推荐
- IE浏览器右键菜单插件开发(下篇)——如何用c#安装、卸载IE右键插件
建立Installer安装类,如图: 代码如下: using Microsoft.Win32; using ResourceShare.UserClient.Common; using System; ...
- Topshelf 一个简化Windows服务开发的宿主服务框架
Topshelf是 基于.net框架开发的宿主服务框架.该框架简化了服务的创建,开发人员只需要使用 Topshelf编写一个控制台程序,就能安装为Windows服务.之所以这样原因非常简单:调试一个控 ...
- JAVA线程sleep和wait方法区别
一. sleep 是线程类(Thread)的方法,导致此线程暂停执行指定时间,给执行机会给其他线程,但是监控状态依然保持,到时后会自动恢复,调用sleep 不会释放对象锁.由于没有释放对象锁,所以不能 ...
- C++中 Rand随机序列函数
标准库<cstdlib>(被包含于<iostream>中)提供两个帮助生成伪随机数的函数: 函数一:int rand(void): 从srand (seed ...
- 关于JDK和eclipse的安装和汉化
参考网址:http://jingyan.baidu.com/article/f96699bb8b38e0894e3c1bef.html http://titanseason.iteye.com/blo ...
- Go a lot of way but I go back to the original point
I try a lot of blog platform and even construct my blog website. But I have to say I just want to ha ...
- V5.7_UTF8_SP1、SP2---任意前台用户登录(cookie伪造)
漏洞触发点在include/memberlogin.class.php中的MemberLogin类中的登录校验函数 可以看到M_ID参数是由GetNum(GetCookie("DedeUse ...
- 原生js实现简单的全屏滚动
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Vue自定义插件方法大全
新年第一天首先祝大家新年快乐,心想事成! 1.利用根实例构造函数的原型 //在构造函数的原型链上添加自定义属性 Vue.prototype.test = 'pomelo' //在其他组件中调用 con ...
- Lucene-02:搜索初步
承接上一篇文章. package com.amazing; import java.io.File; import java.io.IOException; import org.apache.luc ...