利用PYTHON设计计算器功能

通过利用PYTHON 设计处理计算器的功能如:

1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 ))- (-4*3)/(16-3*2))

我的处理计算基本思路是:

解题思路是,需要优先处理内层括号运算--外层括号运算--先乘除后加减的原则:
1、正则处理用户输入的字符串,然后对其进行判断,判断计算公式是否有括号,有就先将计算公式进行正则处理,先获取最里层的每一个数据,然后一一计算

所要用到的正则是:

inner = re.search("\([^()]*\)", calc_input)

2、把有括号的计算公式计算出来的结果替换原来初始公式的位置,计算之前分别对重复运算符进行处理

需要处理的重复运算的函数是

1 def del_double(str):
2     str = str.replace("++", "+")
3     str = str.replace("--", "-")
4     str = str.replace("+-","-")
5     str = str.replace("- -","-")
6     str = str.replace("+ +","+")
7     return str

3、然后依次从里到外去除括号并进行计算,和位置替换

calc_input = calc_input.replace(inner.group(), str(ret))   将计算出来的结果分别替换原计算公式

4、最后得出没有括号的公式,合并调用计算控制函数进行计算,中间需要注意的就是 负号 和数字与*在一起的处理,其它还算可以。

具体逻辑思路图是:

以下是完整的代码:

 1 #!/usr/bin/env python3.5
 2 # -*-coding:utf8-*-
 3 import re
 4 a =r‘1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 ))- (-4*3)/(16-3*2))‘
 5 # */运算函数
 6 def shengchu(str):
 7     calc = re.split("[*/]",str)     #用*/分割公式
 8     OP = re.findall("[*/]",str)    #找出所有*和/号
 9     ret = None
10     for index,i in enumerate(calc):
11         if ret:
12             if OP[index-1] == "*":
13                 ret *= float(i)
14             elif OP[index-1] == "/":
15                 ret /= float(i)
16         else:
17             ret = float(i)
18     return ret
19
20 # 去掉重复运算,和处理特列+-符号
21 def del_double(str):
22     str = str.replace("++", "+")
23     str = str.replace("--", "-")
24     str = str.replace("+-","-")
25     str = str.replace("- -","-")
26     str = str.replace("+ +","+")
27     return str
28 # 计算主控制函数
29 def calc_contrl(str):
30     tag = False
31     str = str.strip("()")  # 去掉最外面的括号
32     str = del_double(str)  # 调用函数处理重复运算
33     find_ = re.findall("[+-]",str) # 获取所有+- 操作符
34     split_ = re.split("[+-]",str) #正则处理 以+-操作符进行分割,分割后 只剩*/运算符
35     if len(split_[0].strip()) == 0:  # 特殊处理
36         split_[1] = find_[0] + split_[1] # 处理第一个数字前有“-”的情况,得到新的带符号的数字
37         # 处理第一个数字前为负数“-",时的情况,可能后面的操作符为“-”则进行标记
38         if len(split_) == 3 and len(find_) ==2:
39             tag =True
40             del split_[0] # 删除原分割数字
41             del find_[0]
42         else:
43             del split_[0] # 删除原分割数字
44             del find_[0]  # 删除原分割运算符
45     for index, i in enumerate(split_):
46         # 去除以*或/结尾的运算数字
47         if i.endswith("* ") or i.endswith("/ "):
48             split_[index] = split_[index] + find_[index] + split_[index+1]
49             del split_[index+1]
50             del find_[index]
51     for index, i in enumerate(split_):
52         if re.search("[*/]",i): # 先计算含*/的公式
53             sub_res = shengchu(i) #调用剩除函数
54             split_[index] = sub_res
55     # 再计算加减
56     res = None
57     for index, i in enumerate(split_):
58         if res:
59             if find_[index-1] == "+":
60                 res += float(i)
61             elif find_[index-1] == "-":
62                 # 如果是两个负数相减则将其相加,否则相减
63                 if tag == True:
64                     res += float(i)
65                 else:
66                     res -= float(i)
67         else:
68             # 处理没有括号时会出现i 为空的情况
69             if i != "":
70                 res = float(i)
71     return res
72
73 if __name__ == ‘__main__‘:
74     calc_input = input("请输入计算公式,默认为:%s:" %a).strip()
75     try:
76         if len(calc_input) ==0:
77             calc_input = a
78         calc_input = r‘%s‘%calc_input  # 做特殊处理,保持字符原形
79         flag = True   # 初始化标志位
80         result = None   # 初始化计算结果
81         # 循环处理去括号
82         while flag:
83             inner = re.search("\([^()]*\)", calc_input)# 先获取最里层括号内的单一内容
84             #print(inner.group())
85             # 有括号时计算
86             if inner:
87                 ret = calc_contrl(inner.group())  # 调用计算控制函数
88                 calc_input = calc_input.replace(inner.group(), str(ret)) # 将运算结果,替换原处理索引值处对应的字符串
89                 print("处理括号内的运算[%s]结果是:%s" % (inner.group(),str(ret)))
90                 #flag = True
91             # 没有括号时计算
92             else:
93                 ret = calc_contrl(calc_input)
94                 print("最终计算结果为:%s"% ret)
95                 #结束计算标志
96                 flag = False
97     except:
98         print("你输入的公式有误请重新输入!")

PYTHON正则表达式一览:

模式 描述
^ 匹配字符串的开头
$ 匹配字符串的末尾。
. 匹配任意字符,除了换行符,当re.DOTALL标记被指定时,则可以匹配包括换行符的任意字符。
[...] 用来表示一组字符,单独列出:[amk] 匹配 ‘a‘,‘m‘或‘k‘
[^...] 不在[]中的字符:[^abc] 匹配除了a,b,c之外的字符。
re* 匹配0个或多个的表达式。
re+ 匹配1个或多个的表达式。
re? 匹配0个或1个由前面的正则表达式定义的片段,非贪婪方式
re{ n}  
re{ n,} 精确匹配n个前面表达式。
re{ n, m} 匹配 n 到 m 次由前面的正则表达式定义的片段,贪婪方式
a| b 匹配a或b
(re) G匹配括号内的表达式,也表示一个组
(?imx) 正则表达式包含三种可选标志:i, m, 或 x 。只影响括号中的区域。
(?-imx) 正则表达式关闭 i, m, 或 x 可选标志。只影响括号中的区域。
(?: re) 类似 (...), 但是不表示一个组
(?imx: re) 在括号中使用i, m, 或 x 可选标志
(?-imx: re) 在括号中不使用i, m, 或 x 可选标志
(?#...) 注释.
(?= re) 前向肯定界定符。如果所含正则表达式,以 ... 表示,在当前位置成功匹配时成功,否则失败。但一旦所含表达式已经尝试,匹配引擎根本没有提高;模式的剩余部分还要尝试界定符的右边。
(?! re) 前向否定界定符。与肯定界定符相反;当所含表达式不能在字符串当前位置匹配时成功
(?> re) 匹配的独立模式,省去回溯。
\w 匹配字母数字
\W 匹配非字母数字
\s 匹配任意空白字符,等价于 [\t\n\r\f].
\S 匹配任意非空字符
\d 匹配任意数字,等价于 [0-9].
\D 匹配任意非数字
\A 匹配字符串开始
\Z 匹配字符串结束,如果是存在换行,只匹配到换行前的结束字符串。c
\z 匹配字符串结束
\G 匹配最后匹配完成的位置。
\b 匹配一个单词边界,也就是指单词和空格间的位置。例如, ‘er\b‘ 可以匹配"never" 中的 ‘er‘,但不能匹配 "verb" 中的 ‘er‘。
\B 匹配非单词边界。‘er\B‘ 能匹配 "verb" 中的 ‘er‘,但不能匹配 "never" 中的 ‘er‘。
\n, \t, 等. 匹配一个换行符。匹配一个制表符。等
\1...\9 匹配第n个分组的子表达式。
\10 匹配第n个分组的子表达式,如果它经匹配。否则指的是八进制字符码的表达式。
时间: 2024-10-29 10:47:39

利用PYTHON设计计算器功能的相关文章

利用python收发邮件功能实现远程电脑的控制

功能并非原创, 只是重复实现了 http://codecloud.net/python-control-128.html 中描述的功能. 实现功能: 通过给固定邮件地址发送命令(包含在主题中)的方式控制远程电脑实现相应功能(譬如关机等, 可以根据实际需要实现更复杂的功能) 实现原理: 远程电脑不断(每隔10s)利用 python 脚本检查邮件服务器是否有新邮件, 如有则对邮件进行分析, 如果包含可执行命令, 则执行相应命令 你需要的: 装有 PYTHON 的 PC; 最好两个邮箱(一个用于接收命

使用python实现计算器功能

学习python过程中的作业.实现了+.-.×./.及幂运算,支持括号优先级. 代码为python3.5 1 import re 2 def formatEquation(string): 3 string = string.replace("--", "+") 4 string = string.replace("-+", "-") 5 string = string.replace("++", &quo

完成一段简单的Python程序,用于实现一个简单的加减乘除计算器功能

#!/bin/usr/env python#coding=utf-8'''完成一段简单的Python程序,用于实现一个简单的加减乘除计算器功能'''try: a=int(raw_input("please input a number:"))except ValueError: print("第一个运算数字输入非数字") try: b=int(raw_input("please input another number:"))except Val

Python_Tips[1] -> 利用 Python 的字典实现 Switch 功能

利用 Python 的字典实现 Switch 功能 Python是没有switch语句的,当遇到需要实现switch语句的功能时,一般可以用if/else进行代替,但是还有一种更加简洁的实现方法,利用字典进行实现,将需要选择的条件设为字典的键,选择的结果设为值,通过字典键索取值的方式实现switch的功能. 1 def hello(): 2 print('Hello!') 3 4 def world(): 5 print('World!') 6 7 d = {'Hello': hello, 8

利用Python数据分析可以实现些什么功能呢?

随着大数据时代的来临和Python编程语言的火爆,Python数据分析早已成为现在职场人的必备核心技能.那么利用Python数据分析可以做什么呢?简单来说,可以做到的内容有很多,比如检查数据表.数据表清洗.数据预处理.数据提取和数据筛选汇总等等.下面来为大家详细讲解一下这些用处 1.检查数据表 Python中使用shape函数来查看数据表的维度,也就是行数和列数.你可以使用info函数查看数据表的整体信息,使用dtypes函数来返回数据格式.Isnull是Python中检验空值的函数,你可以对整

利用python爬取海量疾病名称百度搜索词条目数的爬虫实现

实验原因: 目前有一个医疗百科检索项目,该项目中对关键词进行检索后,返回的结果很多,可惜结果的排序很不好,影响用户体验.简单来说,搜索出来的所有符合疾病中,有可能是最不常见的疾病是排在第一个的,而最有可能的疾病可能需要翻很多页才能找到. 实验目的: 为了优化对搜索结果的排序,想到了利用百度搜索后有显示搜索到多少词条,利用这个词条数,可以有效的对疾病排名进行一个优化.从一方面看,某一个疾病在百度的搜索词条数目越多,表示这个词条的信息特别丰富,侧面反映了搜索这个词条的人特别多,从而可以推出这个疾病在

利用Python实现四则运算表达式生成程序

一. 项目基本信息 项目成员:梁华超.林贤杰 项目仓库:Github 二. PSP2.1表格 PSP2.1 Personal Software Process Stages 预估耗时(分钟) 实际耗时(分钟) Planning 计划 20 25 · Estimate · 估计这个任务需要多少时间 20 25 Development 开发 1200 1740 · Analysis · 需求分析 (包括学习新技术) 40 55 · Design Spec · 生成设计文档 40 41 · Desig

利用python进行数据分析--(阅读笔记一)

以此记录阅读和学习<利用Python进行数据分析>这本书中的觉得重要的点! 第一章:准备工作 1.一组新闻文章可以被处理为一张词频表,这张词频表可以用于情感分析. 2.大多数软件是由两部分代码组成:少量需要占用大部分执行时间的代码,以及大量不经常执行的“粘合剂代码”. cython已经成为python领域中创建编译型扩展以及对接c/c++代码的一大途径. 3.在那些要求延迟性非常小的应用程序中(例如高频交易系统),为了尽最大可能地优化性能,耗费时间使用诸如C++这样更低级.更低生产率的语言进行

利用 Python yield 创建协程将异步编程同步化

在 Lua 和 Python 等脚本语言中,经常提到一个概念: 协程.也经常会有同学对协程的概念及其作用比较疑惑,本文今天就来探讨下协程的前世今生. 首先回答一个大家最关心的问题:协程的好处是什么? 通俗易懂的回答: 让原来要使用 异步 + 回调 方式写的非人类代码,可以用看似同步的方式写出来. 1.回顾同步与异步编程 同步编程即线性化编程,代码按照既定顺序执行,上一条语句执行完才会执行下一条,否则就一直等在那里. 但是许多实际操作都是CPU 密集型任务和 IO 密集型任务,比如网络请求,此时不