python正則表達式之作業(yè)計算器
作業(yè):計算器開發(fā)
實現(xiàn)加減乘除及拓號優(yōu)先級解析
用戶輸入 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)/ (16-3*2) )等類似公式后,必須自己解析里面的(),+,-,*,/符號和公式,運算后得出結(jié)果,結(jié)果必須與真實的計算器所得出的結(jié)果一致
一、說明:
有一點bug就是不能計算冪次方,如:'6**6'會報錯
該計算器思路:
1、沒用使用遞歸,先找出并計算所有括號里的公式,再計算乘除和加減
2、所有的數(shù)字都認為是浮點型操作,以此來保留小數(shù)
使用技術(shù):
1、正則表達式
2、tkinter
二、流程圖:
三、代碼如下:
#!/usr/bin/env python3 #antuor:Alan import re from functools import reduce from tkinter import * '''處理特殊-號運算''' def minus_operation(expresstion): minus_operators = re.split("-",expresstion) calc_list = re.findall("[0-9]",expresstion) if minus_operators[0] =="": calc_list[0] = '-%s' % calc_list[0] res = reduce(lambda x,y:float(x)-float(y),calc_list) print(">>>>>>>>>>>>>>減號[%s]運算結(jié)果:" % expresstion,res) return res '''reduce()對sequence連續(xù)使用function, 如果不給出initial, 則第一次調(diào)用傳遞sequence的兩個元素, 以后把前一次調(diào)用的結(jié)果和sequence的下一個元素傳遞給function''' '''處理雙運算符號''' def del_duplicates(expresstion): expresstion = expresstion.replace("++","+") expresstion = expresstion.replace("--","-") expresstion = expresstion.replace("+-","-") expresstion = expresstion.replace("--","+") expresstion = expresstion.replace('- -',"+") e return expresstion '''*/運算函數(shù)''' def mutiply_dividend(expresstion): calc_list = re.split("[*/]",expresstion) #用* or /分割公式 operators = re.findall("[*/]",expresstion) #找出所有*和/號 res = None for index,i in enumerate(calc_list): if res: if operators[index-1] =='*': res *= float(i) elif operators[index-1] =='/': res /=float(i) else : res = float(i) procession0 = "[%s]運算結(jié)果=" % expresstion,res final_result.insert(END,procession0) #插入窗體 print(procession0) return res '''處理運算符號順序混亂情況''' def special_features(plus_and_minus_operators,multiply_and_dividend): for index,i in enumerate(multiply_and_dividend): i = i.strip() if i.endswith("*") or i.endswith("/"): multiply_and_dividend[index] = multiply_and_dividend[index] + plus_and_minus_operators[index] + multiply_and_dividend[index+1] del multiply_and_dividend[index+1] del plus_and_minus_operators[index] return plus_and_minus_operators,multiply_and_dividend def minus_special(operator_list,calc_list): for index,i in enumerate(calc_list): if i =='': calc_list[index+1] = i + calc_list[index+1].strip() '''運算除了()的公式+-*/''' def figure_up(expresstion): expresstion = expresstion.strip("()") #去掉外面括號 expresstion = del_duplicates(expresstion) #去掉重復+-號 plus_and_minus_operators = re.findall("[+-]",expresstion) multiply_and_dividend = re.split("[+-]",expresstion) if len(multiply_and_dividend[0].strip()) ==0: multiply_and_dividend[1] = plus_and_minus_operators[0] + multiply_and_dividend[1] del multiply_and_dividend[0] del plus_and_minus_operators[0] plus_and_minus_operators,multiply_and_dividend = special_features(plus_and_minus_operators,multiply_and_dividend) for index,i in enumerate(multiply_and_dividend): if re.search("[*/]",i): sub_res = mutiply_dividend(i) multiply_and_dividend[index] = sub_res print(multiply_and_dividend,plus_and_minus_operators) #計算 final_res = None for index,item in enumerate(multiply_and_dividend): if final_res: if plus_and_minus_operators[index-1] == '+': final_res += float(item) elif plus_and_minus_operators[index-1] == '-': final_res -= float(item) else: final_res = float(item) procession = '[%s]計算結(jié)果:' % expresstion,final_res final_result.insert(END,procession) #插入窗體 print(procession) return final_res """主函數(shù):運算邏輯:先計算拓號里的值,算出來后再算乘除,再算加減""" def calculate(): expresstion = expresstions.get() #獲取輸入框值 flage = True calculate_res = None #初始化計算結(jié)果為None while flage: m = re.search("\([^()]*\)",expresstion) #先找最里層的() # pattern = re.compile(r"\([^()]*\)") # m = pattern.match(expresstion) if m: sub_res = figure_up(m.group()) #運算()里的公式 expresstion = expresstion.replace(m.group(),str(sub_res)) #運算完畢把結(jié)果替換掉公式 else: print('---------------括號已經(jīng)計算完畢--------------') procession1 = "最終計算結(jié)果:",figure_up(expresstion) final_result.insert(END,procession1) #插入窗體 print('\033[31m最終計算結(jié)果:',figure_up(expresstion)) flage = False if __name__=="__main__": # res = calculate("1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)/ (16-3*2) )") window = Tk() ###創(chuàng)建窗體 window.title('計算器') ###命名窗體 frame1 = Frame(window) ###框架1 frame1.pack() ###放置 frame2 = Frame(window) ###框架2 frame2.pack() ###放置 lable = Label(frame1,text = "請輸入公式:") ###文字標簽 lable.pack() expresstions = StringVar() ###輸入框?qū)傩裕址? entryname = Entry(frame1,textvariable = expresstions) ###文本輸入框 bt_get_expresstions = Button(frame1,text = "提交",command = calculate) ###按鈕掛件 bt_get_expresstions.pack() entryname.pack() lable.grid(row =1,column =1) ###位置 entryname.grid(row=1,column =2) bt_get_expresstions.grid(row =1,column =3) final_result = Text(frame2) ###計算結(jié)果顯示框 final_result.tag_config("here", background="yellow", foreground="blue") final_result.pack() window.mainloop() ###事件循環(huán)
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助。
相關(guān)文章
Python從入門到實戰(zhàn)之數(shù)據(jù)結(jié)構(gòu)篇
數(shù)據(jù)結(jié)構(gòu)中有很多樹的結(jié)構(gòu),其中包括二叉樹、二叉搜索樹、2-3樹、紅黑樹等等。本文中對數(shù)據(jù)結(jié)構(gòu)進行了總結(jié),不求嚴格精準,但求簡單易懂2021-11-11python+selenium?實現(xiàn)掃碼免密登錄示例代碼
這篇文章主要介紹了python+selenium?實現(xiàn)掃碼免密登錄,首先掃碼登錄獲取cookies保存到本地未后面免密登錄做準備,本文通過示例代碼給大家介紹的非常詳細,需要的朋友可以參考下2022-07-07python使用OS模塊操作系統(tǒng)接口及常用功能詳解
os是?Python?標準庫中的一個模塊,提供了與操作系統(tǒng)交互的功能,在本節(jié)中,我們將介紹os模塊的一些常用功能,并通過實例代碼詳細講解每個知識點2023-06-06