Python之tkinter 計算器的華麗設計

發現一個很可怕的問題,只有手寫小程序的時候纔會發現

無論書籍上面寫的如何,只有在親自動手寫程序的時候,纔會體會到很多知識點書籍是沒有的,可能有,但是也很多都是一筆帶過了,只有去百度查閱各種資料才行

實踐纔是解決問題的根本方法,就像我們讀書一樣,90%都在刷題,只有少數時間在學知識點

學編程也是一樣,只有寫小程序纔會知道自己那個地方不足,才能融會貫通

下面是計算器的小設計:

import tkinter


# 計算
def calculate():
    # 計算
    # equ.get()獲取此時equ內容
    # eval  計算
    result = eval(equ.get())
    # 拼接
    equ.set(equ.get() + "=\n" + str(result))


# 將我們的數字打在文本框上
def show(buttonString):
    # 獲取內容
    content = equ.get()
    # 判斷,如果內容爲0的話相當於沒計算,所以空字符串拼接,還是0
    # 如果內容爲10的話,content就爲10,再拼接我們所按的數字
    if content == "0":
        content = ""
    equ.set(content + buttonString)


# 清除,置爲0
def clear():
    equ.set("0")


# 退位
def backSpace():
    # 刪除前一個字符
    equ.set(str(equ.get()[:-1]))
    

# 主程序
root = tkinter.Tk()
# 設置程序標題
root.title("簡易計算器")
# 框體可拖拽,0,0表示不能拖拽
root.resizable(0, 0)
# equ 是存放顯示區的數字
equ = tkinter.StringVar()
# 默認爲0
equ.set("0")

# 設置文本框
# width 寬爲25
# height 高爲2
# relief  指邊框的浮雕樣式,類似那種3D樣式
# anchor  指文字在組件中的方位,SE就是左下角
# textvariable  指可變的text,會隨着變量的變化而變化
label = tkinter.Label(root, width=25, height=2, relief="raised", anchor=tkinter.SE, textvariable=equ)
# grid  把按鈕整到屏幕上,網格化佈局
# row  指entry組件在網格中的橫向位置
# column  指entry組件在網格中的縱向位置
# columnspan  指設定entry組件在column方向的合併數量
# padx/pady  設定組件邊界與容器(可想成窗口邊界)的距離或是控件邊界間的距離
label.grid(row=0, column=0, columnspan=4, padx=5, pady=5)

# row1的按鈕

# 清除顯示區按鈕AC
# text  按鈕上的文字
# bg  背景色彩
# command  當按鈕點擊時執行clear函數
buttonClear = tkinter.Button(root, text="AC", width=5, bg="#ff6348", command=clear)
buttonClear.grid(row=1, column=0)

# 退位鍵按鈕
buttonBack = tkinter.Button(root, text="<-", width=5, bg="#ff6348", command=backSpace)
buttonBack.grid(row=1, column=1)

# 餘按鈕
# lambda函數  傳參的話需要運用這個lambda
buttonYu = tkinter.Button(root, text="%", width=5, bg="lightblue", command=lambda: show("%"))
buttonYu.grid(row=1, column=2)

# 除按鈕
buttonDivision = tkinter.Button(root, text="/", width=5, bg="lightblue", command=lambda: show("/"))
buttonDivision.grid(row=1, column=3)

# row2的按鈕

# 數字7
button7 = tkinter.Button(root, text="7", width=5, bg="orange", command=lambda: show("7"))
button7.grid(row=2, column=0)

# 數字8
button8 = tkinter.Button(root, text="8", width=5, bg="orange", command=lambda: show("8"))
button8.grid(row=2, column=1)

# 數字9
button9 = tkinter.Button(root, text="9", width=5, bg="orange", command=lambda: show("9"))
button9.grid(row=2, column=2)

# 乘法按鈕
buttonMultiplication = tkinter.Button(root, text="*", width=5, bg="lightblue", command=lambda: show("*"))
buttonMultiplication.grid(row=2, column=3)

# row3的按鈕

# 數字4
button4 = tkinter.Button(root, text="4", width=5, bg="orange", command=lambda: show("4"))
button4.grid(row=3, column=0)

# 數字5
button5 = tkinter.Button(root, text="5", width=5, bg="orange", command=lambda: show("5"))
button5.grid(row=3, column=1)

# 數字6
button6 = tkinter.Button(root, text="6", width=5, bg="orange", command=lambda: show("6"))
button6.grid(row=3, column=2)

# 減法按鈕
buttonSubtraction = tkinter.Button(root, text="-", width=5, bg="lightblue", command=lambda: show("-"))
buttonSubtraction.grid(row=3, column=3)

# row4的按鈕

# 數字1
button1 = tkinter.Button(root, text="1", width=5, bg="orange", command=lambda: show("1"))
button1.grid(row=4, column=0)

# 數字2
button2 = tkinter.Button(root, text="2", width=5, bg="orange", command=lambda: show("2"))
button2.grid(row=4, column=1)

# 數字3
button3 = tkinter.Button(root, text="3", width=5, bg="orange", command=lambda: show("3"))
button3.grid(row=4, column=2)

# 加法按鈕
buttonAdd = tkinter.Button(root, text="+", width=5, bg="lightblue", command=lambda: show("+"))
buttonAdd.grid(row=4, column=3)

# row5的按鈕

# 小數點按鈕
buttonPoint = tkinter.Button(root, text=".", width=5, bg="orange", command=lambda: show("."))
buttonPoint.grid(row=5, column=0)

# 數字0
button0 = tkinter.Button(root, text="0", width=5, bg="orange", command=lambda: show("0"))
button0.grid(row=5, column=1)

# 等於號
buttonEqual = tkinter.Button(root, text="=", width=12, bg="lightgreen", command=calculate)
buttonEqual.grid(row=5, column=2, columnspan=2)

# 程序循環進行
root.mainloop()

運行結果:
在這裏插入圖片描述
因爲比較注重界面,所以判斷輸入的合法性沒有着重的考慮,希望讀者可以優化一下

附:
Mac os系統,因爲color不兼容的緣故,筆者查閱了很多資料,按照目前的文章的知識水平,只有一種不太好的兼容方法,不是不可行,只是沒有跟windows系統差不多的效果

 bg="orange"
 # 替換成
 highlightbackground="orange"

就可以顯示顏色了,但是!!Windows不支持,只有Mac os系統支持這樣,如果Windows替換了,會不顯示顏色的

謝謝觀看,筆者會持續更新,如有錯誤或者建議,請私信我

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章