基于Python的数据库系统开发

我现在已经创建好了数据库完成了系统的登录注册功能,接下想要实现登录成功后的操作(管理员的增删改查)这里的页面跳转怎么实现?(我想要在登录成功弹窗后跳转管理员操作界面),求帮助

用的啥框架,例如flask框架,当你登录完成后,返回到首页不就行了

from flask import Flask,redirect
app = Flask(__name__)

app.route('/demo1')
def index():
    # 判断是否已经登录,若未登录,重定向到登录页面
    if  request.args.get('username') is None:
        return redirect('/login')
    # 若已登录,返回首页
    return render_temple("index.html")

用tkinter实现请看:https://blog.csdn.net/weixin_43287121/article/details/108364270
人家搭建好的脚手架直接套用就行了

建议题主用pyQt 吧。可视化编程,功能强大,界面还美观

import tkinter as tk
#登入界面
def enter():
   root=tk.Tk()
   root.title("欢迎使用图书管理系统")
   lab_1=tk.Label(root,text="请登入")
   but_dr=tk.Button(root,text="登入",command=root.destroy)
   lab_1.grid(row=0,column=0)
   but_dr.grid(row=1,column=1)
   root.mainloop()


enter()
#主程序界面
root2=tk.Tk()
root2.title("欢迎进入图书管理系统")
lab_1=tk.Label(root2,text="第二个界面",height=3)
lab_1.grid(row=0,column=0,sticky="w"+"e")
root2.mainloop()

【参考代码】

给你个示例,你照着抄就可以了,题主关注下主界面和子界面的衔接之处
主函数main.py

from tkinter import *
from LoginPage import *
root = Tk() 
root.title('小程序') 
LoginPage(root) 
root.mainloop() 

登陆界面函数LoginPage.py

from tkinter import *
from tkinter.messagebox import *
from MainPage import *
  
class LoginPage(object): 
 def __init__(self, master=None): 
  self.root = master #定义内部变量root 
  self.root.geometry('%dx%d' % (300, 180)) #设置窗口大小 
  self.username = StringVar() 
  self.password = StringVar() 
  self.createPage() 
  
 def createPage(self): 
  self.page = Frame(self.root) #创建Frame 
  self.page.pack() 
  Label(self.page).grid(row=0, stick=W) 
  Label(self.page, text = '账户: ').grid(row=1, stick=W, pady=10) 
  Entry(self.page, textvariable=self.username).grid(row=1, column=1, stick=E) 
  Label(self.page, text = '密码: ').grid(row=2, stick=W, pady=10) 
  Entry(self.page, textvariable=self.password, show='*').grid(row=2, column=1, stick=E) 
  Button(self.page, text='登陆', command=self.loginCheck).grid(row=3, stick=W, pady=10) 
  Button(self.page, text='退出', command=self.page.quit).grid(row=3, column=1, stick=E) 
  
 def loginCheck(self): 
  name = self.username.get() 
  secret = self.password.get() 
  if name=='wangliang' and secret=='123456': 
   self.page.destroy() 
   MainPage(self.root) 
  else: 
   showinfo(title='错误', message='账号或密码错误!') 

主界面函数MainPage.py

from tkinter import *
from view import * #菜单栏对应的各个子页面 
  
class MainPage(object): 
 def __init__(self, master=None): 
  self.root = master #定义内部变量root 
  self.root.geometry('%dx%d' % (600, 400)) #设置窗口大小 
  self.createPage() 
  
 def createPage(self): 
  self.inputPage = InputFrame(self.root) # 创建不同Frame 
  self.queryPage = QueryFrame(self.root) 
  self.countPage = CountFrame(self.root) 
  self.aboutPage = AboutFrame(self.root) 
  self.inputPage.pack() #默认显示数据录入界面 
  menubar = Menu(self.root) 
  menubar.add_command(label='数据录入', command = self.inputData) 
  menubar.add_command(label='查询', command = self.queryData) 
  menubar.add_command(label='统计', command = self.countData) 
  menubar.add_command(label='关于', command = self.aboutDisp) 
  self.root['menu'] = menubar # 设置菜单栏 
  
 def inputData(self): 
  self.inputPage.pack() 
  self.queryPage.pack_forget() 
  self.countPage.pack_forget() 
  self.aboutPage.pack_forget() 
  
 def queryData(self): 
  self.inputPage.pack_forget() 
  self.queryPage.pack() 
  self.countPage.pack_forget() 
  self.aboutPage.pack_forget() 
  
 def countData(self): 
  self.inputPage.pack_forget() 
  self.queryPage.pack_forget() 
  self.countPage.pack() 
  self.aboutPage.pack_forget() 
  
 def aboutDisp(self): 
  self.inputPage.pack_forget() 
  self.queryPage.pack_forget() 
  self.countPage.pack_forget() 
  self.aboutPage.pack() 

子界面函数view,py

from tkinter import *
from tkinter.messagebox import *
  
class InputFrame(Frame): # 继承Frame类 
 def __init__(self, master=None): 
  Frame.__init__(self, master) 
  self.root = master #定义内部变量root 
  self.itemName = StringVar() 
  self.importPrice = StringVar() 
  self.sellPrice = StringVar() 
  self.deductPrice = StringVar() 
  self.createPage() 
  
 def createPage(self): 
  Label(self).grid(row=0, stick=W, pady=10) 
  Label(self, text = '药品名称: ').grid(row=1, stick=W, pady=10) 
  Entry(self, textvariable=self.itemName).grid(row=1, column=1, stick=E) 
  Label(self, text = '进价 /元: ').grid(row=2, stick=W, pady=10) 
  Entry(self, textvariable=self.importPrice).grid(row=2, column=1, stick=E) 
  Label(self, text = '售价 /元: ').grid(row=3, stick=W, pady=10) 
  Entry(self, textvariable=self.sellPrice).grid(row=3, column=1, stick=E) 
  Label(self, text = '优惠 /元: ').grid(row=4, stick=W, pady=10) 
  Entry(self, textvariable=self.deductPrice).grid(row=4, column=1, stick=E) 
  Button(self, text='录入').grid(row=6, column=1, stick=E, pady=10) 
  
  
class QueryFrame(Frame): # 继承Frame类 
 def __init__(self, master=None): 
  Frame.__init__(self, master) 
  self.root = master #定义内部变量root 
  self.itemName = StringVar() 
  self.createPage() 
  
 def createPage(self): 
  Label(self, text='查询界面').pack() 
  
class CountFrame(Frame): # 继承Frame类 
 def __init__(self, master=None): 
  Frame.__init__(self, master) 
  self.root = master #定义内部变量root 
  self.createPage() 
  
 def createPage(self): 
  Label(self, text='统计界面').pack() 
  
  
class AboutFrame(Frame): # 继承Frame类 
 def __init__(self, master=None): 
  Frame.__init__(self, master) 
  self.root = master #定义内部变量root 
  self.createPage() 
  
 def createPage(self): 
  Label(self, text='关于界面').pack() 

你只是要跳转的逻辑吗? 跳转是新建一个界面,还是覆盖原来的界面?
我之前写的一个,可以到新界面然后增删改查,类似这种

img

使用python+mysql+Django架构,实现起来很快的

参考 https://baijiahao.baidu.com/s?id=1741575741790860944&wfr=spider&for=pc