python制作线性代数计算器
所用函数:
numpy–计算
tkinter,easygu–桌面程序显示
from tkinter import *
import easygui
import numpy as np
import array
master = Tk()
frame = Frame(master) # 确定一个框架用于美观
frame.pack(padx = 200,pady = 100)
v1 = StringVar() # 分别用于储存需要计算的数据和 结果
v2 = StringVar()
v3 = StringVar()
v4 = StringVar()
def test(content):
return content.isdigit() # 检查是不是数字 .
testCMD = frame.register(test) # 将函数 进行包装 .
y1 = Label(frame,text="输入矩阵:",font=('宋体',20)).grid(row=0,column=0)
y2 = Label(frame,text="输入矩阵例子:",font=('宋体',10)).grid(row=5,column=0)
y3 = Label(frame,text="1 2 3,4 5 6,7 8 9(每行之间用英文','隔开,元素之间用空格)",font=('宋体',10)).grid(row=5,column=1)
e1 = Entry(frame,width=150,textvariable=v1,validate='key',\
validatecommand=(test,'%p')).grid(row=0,column=1,pady=10) # %p 是输入框的最新内容 . 当输入框允许改变的时候该值有效 ,
Label(frame,text=':',padx=10).grid(row=0,column=3)
e3 = Entry(frame,width=150,textvariable=v3,state='readonly').grid(row=2,column=1)
e2 = Entry(frame,width=150,textvariable=v2,state='readonly').grid(row=1,column=1)
e4 = Entry(frame,width=150,textvariable=v4,state='readonly').grid(row=3,column=1)
def calc():
if v1.get()=='':
easygui.msgbox('请先输入内容 !')
return
result = v1.get()
dd = [[]]
j=0
for i in result:
if (i>='0') and (i<='9'):
dd[j].append(int(i))
elif i==',' or i==';':
dd.append([])
j+=1
result = np.linalg.det(dd)
v3.set(result)
def calc1():
if v1.get()=='':
easygui.msgbox('请先输入内容 !')
return
result = v1.get()
dd = [[]]
j=0
for i in result:
if (i>='0') and (i<='9'):
dd[j].append(int(i))
elif i==',' or i==';':
dd.append([])
j+=1
try:
result = np.linalg.matrix_rank(dd)
v2.set(result)
except:
v2.set("NULL")
def calc2():
if v1.get()=='':
easygui.msgbox('请先输入内容 !')
return
result = v1.get()
dd = [[]]
j=0
for i in result:
if (i>='0') and (i<='9'):
dd[j].append(int(i))
elif i==',' or i==';':
dd.append([])
j+=1
try:
result = np.linalg.inv(dd)
np.set_printoptions(precision=3, suppress=True)
v4.set(result)
except:
v4.set("NULL")
Button(frame,text='矩阵的秩 ',command=calc1).grid(row=1,column=0,pady=5)
Button(frame,text='矩阵的行列式',command=calc).grid(row=2,column=0,pady=5)
Button(frame,text='矩阵的逆矩阵',command=calc2).grid(row=3,column=0,pady=5)
mainloop()