基于python中thinter以及sqlite3设计一个含有以下模块:********欢迎使用车票订购系统******* 请选择您的进一步操作 1.查询车次信息 2.售票记录和票据信息 3.各站旅客流量统计 4.退出系统 请输入选项:的简单火车订票系统
时间: 2023-08-30 14:10:41 浏览: 110
好的,我可以为您提供一个简单的火车订票系统的设计方案。首先,我们需要安装Python的GUI库tkinter和SQLite3数据库。
在Python中使用SQLite3数据库,我们需要先创建一个数据库文件,并在其中创建表格来存储数据。我们可以创建一个名为“train_tickets.db”的数据库文件,并在其中创建三个表格:车次信息表、售票记录表和旅客流量统计表。
车次信息表包含车次编号、出发站、到达站、出发时间、到达时间、票价等字段。
售票记录表包含订单编号、车次编号、出发站、到达站、出发时间、到达时间、座位号、票价等字段。
旅客流量统计表包含站点名称、日期、进站人数、出站人数、在站人数等字段。
接下来,我们可以设计一个简单的GUI界面,包含一个菜单,菜单中的选项为查询车次信息、售票记录和票据信息、各站旅客流量统计和退出系统。当用户选择某个选项后,程序将从数据库中查询相关数据并在界面上显示。
下面是一个简单的代码示例,仅供参考:
```python
import tkinter as tk
import sqlite3
# 创建GUI界面
root = tk.Tk()
root.title("火车订票系统")
# 创建数据库连接
conn = sqlite3.connect('train_tickets.db')
c = conn.cursor()
# 创建车次信息表
c.execute('''CREATE TABLE IF NOT EXISTS train_info
(train_no TEXT PRIMARY KEY,
depart_station TEXT,
arrive_station TEXT,
depart_time TEXT,
arrive_time TEXT,
price INTEGER)''')
# 创建售票记录表
c.execute('''CREATE TABLE IF NOT EXISTS ticket_info
(order_no TEXT PRIMARY KEY,
train_no TEXT,
depart_station TEXT,
arrive_station TEXT,
depart_time TEXT,
arrive_time TEXT,
seat_no TEXT,
price INTEGER)''')
# 创建旅客流量统计表
c.execute('''CREATE TABLE IF NOT EXISTS passenger_flow
(station_name TEXT,
date TEXT,
in_num INTEGER,
out_num INTEGER,
on_num INTEGER)''')
# 查询车次信息
def query_train_info():
# 获取用户输入
depart_station = depart_station_entry.get()
arrive_station = arrive_station_entry.get()
depart_time = depart_time_entry.get()
# 查询车次信息
c.execute('SELECT * FROM train_info WHERE depart_station=? AND arrive_station=? AND depart_time=?',
(depart_station, arrive_station, depart_time))
train_info = c.fetchall()
# 在界面上显示查询结果
result_text.delete('1.0', tk.END)
for info in train_info:
result_text.insert(tk.END, f'车次编号:{info[0]}\n')
result_text.insert(tk.END, f'出发站:{info[1]}\n')
result_text.insert(tk.END, f'到达站:{info[2]}\n')
result_text.insert(tk.END, f'出发时间:{info[3]}\n')
result_text.insert(tk.END, f'到达时间:{info[4]}\n')
result_text.insert(tk.END, f'票价:{info[5]}\n\n')
# 查询售票记录和票据信息
def query_ticket_info():
# 获取用户输入
order_no = order_no_entry.get()
# 查询售票记录和票据信息
c.execute('SELECT * FROM ticket_info WHERE order_no=?', (order_no,))
ticket_info = c.fetchall()
# 在界面上显示查询结果
result_text.delete('1.0', tk.END)
for info in ticket_info:
result_text.insert(tk.END, f'订单编号:{info[0]}\n')
result_text.insert(tk.END, f'车次编号:{info[1]}\n')
result_text.insert(tk.END, f'出发站:{info[2]}\n')
result_text.insert(tk.END, f'到达站:{info[3]}\n')
result_text.insert(tk.END, f'出发时间:{info[4]}\n')
result_text.insert(tk.END, f'到达时间:{info[5]}\n')
result_text.insert(tk.END, f'座位号:{info[6]}\n')
result_text.insert(tk.END, f'票价:{info[7]}\n\n')
# 查询各站旅客流量统计
def query_passenger_flow():
# 获取用户输入
station_name = station_name_entry.get()
date = date_entry.get()
# 查询各站旅客流量统计
c.execute('SELECT * FROM passenger_flow WHERE station_name=? AND date=?', (station_name, date))
passenger_flow = c.fetchall()
# 在界面上显示查询结果
result_text.delete('1.0', tk.END)
for info in passenger_flow:
result_text.insert(tk.END, f'站点名称:{info[0]}\n')
result_text.insert(tk.END, f'日期:{info[1]}\n')
result_text.insert(tk.END, f'进站人数:{info[2]}\n')
result_text.insert(tk.END, f'出站人数:{info[3]}\n')
result_text.insert(tk.END, f'在站人数:{info[4]}\n\n')
# 创建菜单
menu_label = tk.Label(root, text="请选择您的进一步操作:")
menu_label.grid(row=0, column=0, columnspan=2)
query_train_info_button = tk.Button(root, text="查询车次信息", command=query_train_info)
query_train_info_button.grid(row=1, column=0)
depart_station_label = tk.Label(root, text="出发站:")
depart_station_label.grid(row=2, column=0)
depart_station_entry = tk.Entry(root)
depart_station_entry.grid(row=2, column=1)
arrive_station_label = tk.Label(root, text="到达站:")
arrive_station_label.grid(row=3, column=0)
arrive_station_entry = tk.Entry(root)
arrive_station_entry.grid(row=3, column=1)
depart_time_label = tk.Label(root, text="出发时间:")
depart_time_label.grid(row=4, column=0)
depart_time_entry = tk.Entry(root)
depart_time_entry.grid(row=4, column=1)
query_ticket_info_button = tk.Button(root, text="查询售票记录和票据信息", command=query_ticket_info)
query_ticket_info_button.grid(row=5, column=0)
order_no_label = tk.Label(root, text="订单编号:")
order_no_label.grid(row=6, column=0)
order_no_entry = tk.Entry(root)
order_no_entry.grid(row=6, column=1)
query_passenger_flow_button = tk.Button(root, text="各站旅客流量统计", command=query_passenger_flow)
query_passenger_flow_button.grid(row=7, column=0)
station_name_label = tk.Label(root, text="站点名称:")
station_name_label.grid(row=8, column=0)
station_name_entry = tk.Entry(root)
station_name_entry.grid(row=8, column=1)
date_label = tk.Label(root, text="日期:")
date_label.grid(row=9, column=0)
date_entry = tk.Entry(root)
date_entry.grid(row=9, column=1)
result_text = tk.Text(root)
result_text.grid(row=10, column=0, columnspan=2)
exit_button = tk.Button(root, text="退出系统", command=root.quit)
exit_button.grid(row=11, column=0, columnspan=2)
# 运行GUI界面
root.mainloop()
# 关闭数据库连接
conn.close()
```
这个程序使用了SQLite3数据库存储车次信息、售票记录和旅客流量统计信息,并提供了一个简单的GUI界面,让用户可以通过界面来查询相关信息。当用户点击某个查询按钮时,程序将从数据库中查询相关数据,并在界面上显示查询结果。
阅读全文