- Python 基础
- Python - 首页
- Python - 概述
- Python - 历史
- Python - 特性
- Python vs C++
- Python - Hello World 程序
- Python - 应用领域
- Python - 解释器
- Python - 环境搭建
- Python - 虚拟环境
- Python - 基本语法
- Python - 变量
- Python - 数据类型
- Python - 类型转换
- Python - Unicode 系统
- Python - 字面量
- Python - 运算符
- Python - 算术运算符
- Python - 比较运算符
- Python - 赋值运算符
- Python - 逻辑运算符
- Python - 位运算符
- Python - 成员运算符
- Python - 身份运算符
- Python - 运算符优先级
- Python - 注释
- Python - 用户输入
- Python - 数字
- Python - 布尔值
- Python 控制语句
- Python - 控制流
- Python - 决策
- Python - if 语句
- Python - if else
- Python - 嵌套 if
- Python - match-case 语句
- Python - 循环
- Python - for 循环
- Python - for-else 循环
- Python - while 循环
- Python - break 语句
- Python - continue 语句
- Python - pass 语句
- Python - 嵌套循环
- Python 函数与模块
- Python - 函数
- Python - 默认参数
- Python - 关键字参数
- Python - 仅限关键字参数
- Python - 位置参数
- Python - 仅限位置参数
- Python - 可变参数
- Python - 变量作用域
- Python - 函数注解
- Python - 模块
- Python - 内置函数
- Python 字符串
- Python - 字符串
- Python - 字符串切片
- Python - 修改字符串
- Python - 字符串连接
- Python - 字符串格式化
- Python - 转义字符
- Python - 字符串方法
- Python - 字符串练习
- Python 列表
- Python - 列表
- Python - 访问列表元素
- Python - 修改列表元素
- Python - 添加列表元素
- Python - 删除列表元素
- Python - 遍历列表
- Python - 列表推导式
- Python - 排序列表
- Python - 复制列表
- Python - 合并列表
- Python - 列表方法
- Python - 列表练习
- Python 元组
- Python - 元组
- Python - 访问元组元素
- Python - 更新元组
- Python - 解包元组
- Python - 遍历元组
- Python - 合并元组
- Python - 元组方法
- Python - 元组练习
- Python 集合
- Python - 集合
- Python - 访问集合元素
- Python - 添加集合元素
- Python - 删除集合元素
- Python - 遍历集合
- Python - 合并集合
- Python - 复制集合
- Python - 集合运算符
- Python - 集合方法
- Python - 集合练习
- Python 字典
- Python - 字典
- Python - 访问字典元素
- Python - 修改字典元素
- Python - 添加字典元素
- Python - 删除字典元素
- Python - 字典视图对象
- Python - 遍历字典
- Python - 复制字典
- Python - 嵌套字典
- Python - 字典方法
- Python - 字典练习
- Python 数组
- Python - 数组
- Python - 访问数组元素
- Python - 添加数组元素
- Python - 删除数组元素
- Python - 遍历数组
- Python - 复制数组
- Python - 反转数组
- Python - 排序数组
- Python - 合并数组
- Python - 数组方法
- Python - 数组练习
- Python 文件处理
- Python - 文件处理
- Python - 写入文件
- Python - 读取文件
- Python - 重命名和删除文件
- Python - 目录
- Python - 文件方法
- Python - OS 文件/目录方法
- Python - OS 路径方法
- 面向对象编程
- Python - OOPs 概念
- Python - 类与对象
- Python - 类属性
- Python - 类方法
- Python - 静态方法
- Python - 构造函数
- Python - 访问修饰符
- Python - 继承
- Python - 多态
- Python - 方法重写
- Python - 方法重载
- Python - 动态绑定
- Python - 动态类型
- Python - 抽象
- Python - 封装
- Python - 接口
- Python - 包
- Python - 内部类
- Python - 匿名类和对象
- Python - 单例类
- Python - 包装类
- Python - 枚举
- Python - 反射
- Python 错误与异常
- Python - 语法错误
- Python - 异常
- Python - try-except 块
- Python - try-finally 块
- Python - 抛出异常
- Python - 异常链
- Python - 嵌套 try 块
- Python - 用户自定义异常
- Python - 日志记录
- Python - 断言
- Python - 内置异常
- Python 多线程
- Python - 多线程
- Python - 线程生命周期
- Python - 创建线程
- Python - 启动线程
- Python - 加入线程
- Python - 线程命名
- Python - 线程调度
- Python - 线程池
- Python - 主线程
- Python - 线程优先级
- Python - 守护线程
- Python - 线程同步
- Python 同步
- Python - 线程间通信
- Python - 线程死锁
- Python - 中断线程
- Python 网络编程
- Python - 网络编程
- Python - 套接字编程
- Python - URL 处理
- Python - 泛型
- Python 库
- NumPy 教程
- Pandas 教程
- SciPy 教程
- Matplotlib 教程
- Django 教程
- OpenCV 教程
- Python 其他
- Python - 日期与时间
- Python - 数学
- Python - 迭代器
- Python - 生成器
- Python - 闭包
- Python - 装饰器
- Python - 递归
- Python - 正则表达式
- Python - PIP
- Python - 数据库访问
- Python - 弱引用
- Python - 序列化
- Python - 模板
- Python - 输出格式化
- Python - 性能测量
- Python - 数据压缩
- Python - CGI 编程
- Python - XML 处理
- Python - GUI 编程
- Python - 命令行参数
- Python - 文档字符串
- Python - JSON
- Python - 发送邮件
- Python - 扩展
- Python - 工具/实用程序
- Python - GUIs
- Python 高级概念
- Python - 抽象基类
- Python - 自定义异常
- Python - 高阶函数
- Python - 对象内部
- Python - 内存管理
- Python - 元类
- Python - 使用元类进行元编程
- Python - 模拟和存根
- Python - Monkey Patching
- Python - 信号处理
- Python - 类型提示
- Python - 自动化教程
- Python - Humanize 包
- Python - 上下文管理器
- Python - 协程
- Python - 描述符
- Python - 诊断和修复内存泄漏
- Python - 不可变数据结构
- Python 有用资源
- Python - 问答
- Python - 在线测验
- Python - 快速指南
- Python - 参考
- Python - 速查表
- Python - 项目
- Python - 有用资源
- Python - 讨论
- Python 编译器
- NumPy 编译器
- Matplotlib 编译器
- SciPy 编译器
Python - 快递追踪管理系统
在这里,我们将学习如何使用 Python tkinter 库和 SQLite 数据库设计一个快递追踪管理系统,该系统具有用户注册、登录以及通过手机号码追踪货物状态等功能。
功能
此应用程序包含以下功能:
- 重复注册和登录选项
- 它还支持通过手机号码追踪货物。
- 包括告知客户产品和目的地信息。
所需库
要创建快递追踪管理系统,您需要安装以下库:
- tkinter − 它是一个 Python 的内置 GUI 接口,主要用于创建基于窗口的应用程序。它用于开发用户界面,以便用户能够与系统交互。
- SQLite3 − SQLite 是一个 C 库,它以 x86 机器码实现,是一个轻量级的基于磁盘的数据库。它非常适合小型应用程序,在这种应用程序中不需要数据库服务器的全部服务。使用 SQLite 不需要单独安装,因为它包含在 Python 中。
- random − random 模块用于获取产品的随机货物编号。此模块是 Python 的一部分,您无需安装它。
应用程序工作流程和功能组件
1. 数据库设置
首先创建一个 SQLite 数据库,并定义一个 user 表来存储用户的用户名、密码和手机号码。CREATE TABLE IF NOT EXISTS 查询确保表仅在不存在时才创建。
2. 类结构
程序的主要功能位于主类中。在这里,我们看到控制 GUI 行为和数据库交互的所有变量和方法。
3. 登录
login() 方法将用户输入的凭据与 SQLite 数据库中的记录进行比较。如果凭据匹配,则对用户进行身份验证并允许其追踪产品。
4. 新用户注册
在 new_user() 方法中,我们允许新用户通过输入用户名、密码和手机号码创建帐户。系统会在将新记录添加到数据库之前检查用户名是否存在。
5. 追踪快递
登录后,用户可以通过输入手机号并选择产品来追踪他们的快递。快递方法从数据库中检索快递详情,在UI中显示它们,并生成一个随机的产品ID。
6. GUI 组件
组件方法定义所有GUI组件,包括标签、输入字段、按钮和组合框。它创建登录、注册和货物追踪表单的主布局。
快递追踪管理系统 Python 代码
以下是设计此应用程序的完整代码:
from tkinter import * from tkinter import messagebox as ms from tkinter import ttk import sqlite3 import random # Database with sqlite3.connect('Akash5.db') as db: c = db.cursor() try: c.execute('CREATE TABLE IF NOT EXISTS user (username TEXT NOT NULL, password TEXT NOT NULL, mobile TEXT NOT NULL);') except: pass db.commit() db.close() class main: def __init__(self, master): self.master = master self.username = StringVar() self.password = StringVar() self.n_username = StringVar() self.n_password = StringVar() self.n_reg = StringVar() self.n_mobile = StringVar() self.mobile11 = StringVar() self.destination = StringVar() self.selected_product = StringVar() self.widgets() def login(self): with sqlite3.connect('Akash5.db') as db: c = db.cursor() find_user = ('SELECT * FROM user WHERE username = ? and password = ?') c.execute(find_user, [(self.username.get()), (self.password.get())]) result = c.fetchall() if result: self.track() else: ms.showerror('Oops!', 'Username Not Found.') def new_user(self): with sqlite3.connect('Akash5.db') as db: c = db.cursor() if self.n_username.get() != ' ' and self.n_password.get() != ' ' and self.n_mobile.get() != ' ': find_user = ('SELECT * FROM user WHERE username = ?') c.execute(find_user, [(self.n_username.get())]) if c.fetchall(): ms.showerror('Error!', 'Username Taken. Try a Different One.') else: insert = 'INSERT INTO user(username, password, mobile) VALUES(?, ?, ?)' c.execute(insert, [(self.n_username.get()), (self.n_password.get()), (self.n_mobile.get())]) db.commit() ms.showinfo('Success!', 'Account Created!') self.log() else: ms.showerror('Error!', 'Please Enter the details.') def consignment(self): try: with sqlite3.connect('Akash5.db') as db: c = db.cursor() find_user = ('SELECT * FROM user WHERE mobile= ?') c.execute(find_user, [(self.mobile11.get())]) result = c.fetchall() if result: self.track() self.crff.pack_forget() self.head['text'] = self.username.get() + '\n Your Product Details' # Get the latest value of destination before packing the frame destination_value = self.destination.get() # Update product details in consi frame self.consi.pack() for widget in self.consi.winfo_children(): widget.destroy() # Clear previous widgets in consi frame Label(self.consi, text='Product ID:', font=('Arial', 15), pady=5, padx=5, fg="white", bg="black").grid(sticky=W) Label(self.consi, text=random.randint(565154, 99994216), font=('Arial', 13), pady=5, padx=5, fg="white", bg="black").grid(row=0, column=1) Label(self.consi, text='Product Name:', font=('Arial', 15), pady=5, padx=5, fg="white", bg="black").grid(sticky=W) Label(self.consi, text=self.selected_product.get(), font=('Arial', 13), pady=5, padx=5, fg="white", bg="black").grid(row=1, column=1) Label(self.consi, text='Destination:', font=('Arial', 15), pady=5, padx=5, fg="white", bg="black").grid(sticky=W) Label(self.consi, text=destination_value, font=('Arial', 13), pady=5, padx=5, fg="white", bg="black").grid(row=2, column=1) Label(self.consi, text='Product Status: Pending', font=('Arial', 15), pady=5, padx=5, fg="white", bg="black").grid(row=3, column=1) Button(self.consi, text='Back', bd=2, font=('Arial', 13), padx=6, pady=6, command=self.track1, bg="gray").grid(row=4, column=0) else: ms.showerror('Oops!', 'Mobile Number Not Found.') except: ms.showerror('Oops!', 'Mobile Number Not Found.') def track1(self): self.consi.pack_forget() self.head['text'] = self.username.get() + '\n Track your Product' self.crff.pack() def log(self): self.username.set('') self.password.set('') self.crf.pack_forget() self.head['text'] = 'Login' self.logf.pack() def cr(self): self.n_username.set('') self.n_password.set('') self.logf.pack_forget() self.head['text'] = 'Create Account' self.crf.pack() def track(self): self.logf.pack_forget() self.head['text'] = self.username.get() + '\n Track your Product' self.crff.pack() def widgets(self): self.head = Label(self.master, text='LOGIN', font=('Arial', 20), pady=10, fg="white", bg="black") self.head.pack() self.logf = Frame(self.master, padx=10, pady=10, bg="black") Label(self.logf, text='Username:', font=('Arial', 15), pady=5, padx=5, fg="white", bg="black").grid(sticky=W) Entry(self.logf, textvariable=self.username, bd=3, font=('Arial', 15)).grid(row=0, column=1) Label(self.logf, text='Password:', font=('Arial', 15), pady=5, padx=5, fg="white", bg="black").grid(sticky=W) Entry(self.logf, textvariable=self.password, bd=3, font=('Arial', 15), show='*').grid(row=1, column=1) Button(self.logf, text=' Login ', bd=2, font=('Arial', 13), padx=6, pady=6, command=self.login, bg="gray").grid(row=8, column=0) Button(self.logf, text=' New user ', bd=2, font=('Arial', 13), padx=6, pady=6, command=self.cr, bg="gray").grid(row=8, column=1) self.logf.pack() self.crf = Frame(self.master, padx=10, pady=10, bg="black") Label(self.crf, text='Username:', font=('Arial', 15), pady=5, padx=5, fg="white", bg="black").grid(sticky=W) Entry(self.crf, textvariable=self.n_username, bd=3, font=('Arial', 15)).grid(row=0, column=1) Label(self.crf, text='Password:', font=('Arial', 15), pady=5, padx=5, fg="white", bg="black").grid(sticky=W) Entry(self.crf, textvariable=self.n_password, bd=3, font=('Arial', 15), show='*').grid(row=1, column=1) Label(self.crf, text='Mobile No.:', font=('Arial', 15), pady=5, padx=5, fg="white", bg="black").grid(sticky=W) Entry(self.crf, textvariable=self.n_mobile, bd=3, font=('Arial', 15)).grid(row=5, column=1) Button(self.crf, text='Create Account', bd=2, font=('Arial', 13), padx=6, pady=6, command=self.new_user, bg="gray").grid(row=11, column=0) Button(self.crf, text='Go to Login', bd=2, font=('Arial', 13), padx=6, pady=6, command=self.log, bg="gray").grid(row=11, column=1) self.crff = Frame(self.master, padx=10, pady=10, bg="black") Label(self.crff, text='Consignment No:', font=('Arial', 15), pady=5, padx=5, fg="white", bg="black").grid(sticky=W) Entry(self.crff, bd=3, font=('Arial', 15)).grid(row=0, column=1) Label(self.crff, text='Mobile no:', font=('Arial', 15), pady=5, padx=5, fg="white", bg="black").grid(sticky=W) Entry(self.crff, bd=3, textvariable=self.mobile11, font=('Arial', 15)).grid(row=1, column=1) Label(self.crff, text="Select Product:", font=('Arial', 15), pady=5, padx=5, fg="white", bg="black").grid(sticky=W) self.selected_product.set("Bag") products = ["Bag", "Colgate", "Shoe", "Redmi 2", "Jeans", "Mac", "Ipad", "Pen", "Book", "Shirt"] product_menu = ttk.Combobox(self.crff, textvariable=self.selected_product, values=products, font=('Arial', 13)) product_menu.grid(row=2, column=1) Label(self.crff, text="Destination:", font=('Arial', 15), pady=5, padx=5, fg="white", bg="black").grid(sticky=W) Entry(self.crff, textvariable=self.destination, bd=3, font=('Arial', 15)).grid(row=3, column=1) Button(self.crff, text='Track', bd=2, font=('Arial', 13), padx=6, pady=6, command=self.consignment, bg="gray").grid(row=4, column=0) self.consi = Frame(self.master, padx=10, pady=10, bg="black") Label(self.consi, text='Product ID:', font=('Arial', 15), pady=5, padx=5, fg="white", bg="black").grid(sticky=W) Label(self.consi, text=random.randint(565154, 99994216), font=('Arial', 13), pady=5, padx=5, fg="white", bg="black").grid(row=0, column=1) Label(self.consi, text='Product Name:', font=('Arial', 15), pady=5, padx=5, fg="white", bg="black").grid(sticky=W) Label(self.consi, text=self.selected_product.get(), font=('Arial', 13), pady=5, padx=5, fg="white", bg="black").grid(row=1, column=1) Label(self.consi, text='Destination:', font=('Arial', 15), pady=5, padx=5, fg="white", bg="black").grid(sticky=W) Label(self.consi, text=self.destination.get(), font=('Arial', 13), pady=5, padx=5, fg="white", bg="black").grid(row=2, column=1) Label(self.consi, text='Product Status: Pending', font=('Arial', 15), pady=5, padx=5, fg="white", bg="black").grid(row=3, column=1) Button(self.consi, text='Back', bd=2, font=('Arial', 13), padx=6, pady=6, command=self.track1, bg="gray").grid(row=4, column=0) if __name__ == '__main__': root = Tk() root.title('Track Consignment') root.geometry('800x450+300+300') root.configure(bg='black') # Set background to black main(root) root.mainloop()
应用程序说明及输出截图
1. 登录界面
这是用户启动应用程序时看到的第一个界面。登录界面包括:用户名和密码输入字段,登录和新用户注册按钮。
2. 新用户注册界面
当用户点击“新用户”按钮时,他们将进入注册界面。我们创建了新用户名“Rama DAS”并添加了密码和手机号。此表单要求用户提供:
3. 快递追踪界面
用户成功登录后,将进入货物追踪界面。他们可以输入手机号查找与其关联的货物。选择产品并查看其详细信息,例如目的地和状态。
4. 快递详情输出
输入手机号和产品后,系统将显示快递详情,例如:产品ID(随机生成)、产品名称、目的地、状态(默认为待处理)。
代码说明
- 导入库 - 脚本首先导入一些模块,主要用于Tkinter中的GUI开发,sqlite3中的数据库操作以及random中的随机数获取。
- 数据库设置 - 它创建一个名为“Akash5.db”的新SQLite数据库,如果不存在,它还会设置用户表,用于存储用户信息,例如凭据和/或手机号。
- 类定义 - 这是一个主类,包含所有应用程序逻辑、数据库连接和GUI管理。
- 初始化 - 在__init__方法中,类创建StringVar变量,用于存储用户的输入和产品详细信息。
- 登录方法 - 登录方法检查用户输入与数据库中存储的数据是否一致。如果找到,它将调用track()方法;如果没有找到,则显示错误消息。
- 新用户方法 - 称为new_user的方法负责创建帐户。它首先验证给定的用户名是否在数据库中可用,然后为新用户创建一个新条目。
- 货物追踪方法 - 在此方法中,用户可以通过输入手机号作为代码来追踪货物。如果找到手机号,则显示货物信息。
- Track1 方法 - 通过这种方式,货物详细信息框架被最小化,而产品追踪界面出现在屏幕上。
- Log 方法 - log方法清除登录文本字段并切换到登录界面。
- Cr 方法 - cr方法清除注册字段并转到帐户创建屏幕。
- Track 方法 - 此方法将GUI切换到货物追踪框架。
- Widgets 方法 - 此方法显示整个GUI,包括登录、注册、货物追踪和产品详情框架。
- 登录框架 - 它包含登录框架(logf),其中包含用于输入用户名和密码的框,以及“登录”和“创建帐户”按钮。
- 注册框架 - 注册框架 (crf) 包含用户名、密码和手机号,以及创建新帐户和转到登录的选项。
- 货物追踪框架 - 在货物追踪框架 (crff) 中,有一些字段,例如货物编号、用于识别客户的手机号和产品选择,以及用于追踪货物的目的地货物按钮。
- 货物详情框架 - 货物详情框架 (consi) 显示货物的详细信息,包括产品的ID、名称和目的地。
- 随机产品ID - randint() 方法为货物详情选择一个随机产品ID。
- 产品选择 - 对于允许用户选择产品的字段,这里使用的是下拉列表(借助ttk.combobox)。
- 错误处理 - 使用最简单的异常处理形式,其中使用消息框显示无效输入或未找到手机号的错误消息。
- 主执行 - 脚本是第一个TI-Kinter脚本,它通过提供标题和大小创建了一个GUI窗口,并通过创建主类的实例来启动应用程序。
python_reference.htm
广告