Python3 Tkinter + SQLite GUI登录注册界面

Python3 Tkinkter + SQLite 实现登录和注册界面

Ubuntu14 + Python3.4 + Pycharm2018

一、设计数据库

数据库内容(login.db):用户名,密码,邮箱,密码错误次数(达到三次时锁定)

create table loginuser (
  username varchar(30) NOT NULL PRIMARY KEY ,
  password varchar(16) NOT NULL ,
  email varchar NOT NULL ,
  loginerror int
);

二、登录界面Tkinter

login.py

1.登录界面代码

2.注册界面代码

from tkinter import *
import sqlite3
import tkinter.messagebox as messagebox


class LoginPage:
    """登录界面"""
    def __init__(self, master):
        self.root = master
        self.root.geometry('400x200+600+400')
        self.root.title('项目资源管理平台Alpha0.1')
        self.conn = sqlite3.connect('data/login.db')
        self.username = StringVar()
        self.password 
  • 14
    点赞
  • 82
    收藏
    觉得还不错? 一键收藏
  • 22
    评论
好的,你的问题是如何使用Tkintersqlite实现台账管理系统,并且满足增删改查和支持数据导入导出的要求。 首先,我们需要安装sqlite3模块,它是Python内置的模块,无需额外安装。然后,我们需要创建一个sqlite数据库来保存我们的数据。 接下来,我们可以使用Tkinter来创建一个图形界面,让用户可以方便地进行数据的增删改查操作。我们可以使用Tkinter的各种控件来实现这些功能,如Entry、Button、Label、Listbox等。 为了实现数据的导入导出,我们可以使用Python内置的CSV模块来进行操作。我们可以将数据导出为CSV文件,然后再将CSV文件导入到我们的台账系统中。 以下是一个简单的Tkinter+sqlite实现台账管理系统的示例代码,你可以参考一下: ```python import tkinter as tk import sqlite3 import csv class LedgerApp: def __init__(self): self.conn = sqlite3.connect('ledger.db') self.create_table() self.create_gui() def create_table(self): cursor = self.conn.cursor() cursor.execute('''CREATE TABLE IF NOT EXISTS ledger (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, quantity INTEGER, price REAL)''') self.conn.commit() def create_gui(self): self.root = tk.Tk() self.root.title('台账管理系统') # 姓名 tk.Label(self.root, text='姓名').grid(row=0, column=0) self.name_entry = tk.Entry(self.root) self.name_entry.grid(row=0, column=1) # 数量 tk.Label(self.root, text='数量').grid(row=1, column=0) self.quantity_entry = tk.Entry(self.root) self.quantity_entry.grid(row=1, column=1) # 价格 tk.Label(self.root, text='价格').grid(row=2, column=0) self.price_entry = tk.Entry(self.root) self.price_entry.grid(row=2, column=1) # 按钮 tk.Button(self.root, text='添加', command=self.add_item).grid(row=3, column=0) tk.Button(self.root, text='删除', command=self.delete_item).grid(row=3, column=1) tk.Button(self.root, text='修改', command=self.update_item).grid(row=3, column=2) tk.Button(self.root, text='查询', command=self.search_item).grid(row=3, column=3) tk.Button(self.root, text='导出', command=self.export_data).grid(row=4, column=0) tk.Button(self.root, text='导入', command=self.import_data).grid(row=4, column=1) # 列表框 self.listbox = tk.Listbox(self.root) self.listbox.grid(row=5, column=0, columnspan=4) self.load_data() def load_data(self): cursor = self.conn.cursor() cursor.execute('SELECT * FROM ledger') rows = cursor.fetchall() for row in rows: self.listbox.insert(tk.END, f'{row[0]} {row[1]} {row[2]} {row[3]}') def add_item(self): name = self.name_entry.get() quantity = self.quantity_entry.get() price = self.price_entry.get() cursor = self.conn.cursor() cursor.execute('''INSERT INTO ledger (name, quantity, price) VALUES (?, ?, ?)''', (name, quantity, price)) self.conn.commit() self.listbox.insert(tk.END, f'{cursor.lastrowid} {name} {quantity} {price}') def delete_item(self): selection = self.listbox.curselection() if selection: id = int(self.listbox.get(selection[0]).split()[0]) cursor = self.conn.cursor() cursor.execute('DELETE FROM ledger WHERE id=?', (id,)) self.conn.commit() self.listbox.delete(selection) def update_item(self): selection = self.listbox.curselection() if selection: id = int(self.listbox.get(selection[0]).split()[0]) name = self.name_entry.get() quantity = self.quantity_entry.get() price = self.price_entry.get() cursor = self.conn.cursor() cursor.execute('''UPDATE ledger SET name=?, quantity=?, price=? WHERE id=?''', (name, quantity, price, id)) self.conn.commit() self.listbox.delete(selection) self.listbox.insert(selection[0], f'{id} {name} {quantity} {price}') def search_item(self): name = self.name_entry.get() quantity = self.quantity_entry.get() price = self.price_entry.get() cursor = self.conn.cursor() cursor.execute('''SELECT * FROM ledger WHERE name=? OR quantity=? OR price=?''', (name, quantity, price)) rows = cursor.fetchall() self.listbox.delete(0, tk.END) for row in rows: self.listbox.insert(tk.END, f'{row[0]} {row[1]} {row[2]} {row[3]}') def export_data(self): cursor = self.conn.cursor() cursor.execute('SELECT * FROM ledger') rows = cursor.fetchall() with open('ledger.csv', 'w', newline='') as f: writer = csv.writer(f) writer.writerow(['id', 'name', 'quantity', 'price']) for row in rows: writer.writerow(row) def import_data(self): with open('ledger.csv', newline='') as f: reader = csv.reader(f) next(reader) # 跳过标题行 for row in reader: cursor = self.conn.cursor() cursor.execute('''INSERT INTO ledger (id, name, quantity, price) VALUES (?, ?, ?, ?)''', (row[0], row[1], row[2], row[3])) self.conn.commit() self.listbox.insert(tk.END, f'{row[0]} {row[1]} {row[2]} {row[3]}') def run(self): self.root.mainloop() if __name__ == '__main__': app = LedgerApp() app.run() ``` 注意:这只是一个示例代码,实际应用中还需要进行一些改进和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 22
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值