python制作线性代数计算器

5 篇文章 0 订阅
2 篇文章 0 订阅

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()
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值