python编程:创建 SQLite 数据库和表的图形用户界面应用程序

在本文中,我将介绍如何使用 wxPython 模块创建一个图形用户界面(GUI)应用程序,该应用程序允许用户选择 SQLite 数据库的存放路径、数据库名称、表名称,并动态添加字段及其类型。以下是具体的实现步骤和代码示例。
C:\pythoncode\new\sqlitegenerator.py

环境准备

首先,确保你已经安装了 wxPythonsqlite3 模块。你可以使用以下命令安装 wxPython

pip install wxPython
代码实现

下面是完整的代码实现:

import wx
import sqlite3
import osclass SQLiteDBCreator(wx.Frame):def __init__(self, parent, title):super(SQLiteDBCreator, self).__init__(parent, title=title, size=(600, 500))self.panel = wx.Panel(self)vbox = wx.BoxSizer(wx.VERTICAL)# Database Pathhbox1 = wx.BoxSizer(wx.HORIZONTAL)self.db_path_text = wx.TextCtrl(self.panel)db_path_btn = wx.Button(self.panel, label='Select Path')db_path_btn.Bind(wx.EVT_BUTTON, self.on_select_path)hbox1.Add(self.db_path_text, proportion=1, flag=wx.EXPAND|wx.ALL, border=5)hbox1.Add(db_path_btn, flag=wx.ALL, border=5)# Database Namehbox2 = wx.BoxSizer(wx.HORIZONTAL)db_name_lbl = wx.StaticText(self.panel, label="Database Name:")self.db_name_text = wx.TextCtrl(self.panel)hbox2.Add(db_name_lbl, flag=wx.ALL, border=5)hbox2.Add(self.db_name_text, proportion=1, flag=wx.EXPAND|wx.ALL, border=5)# Table Namehbox3 = wx.BoxSizer(wx.HORIZONTAL)table_name_lbl = wx.StaticText(self.panel, label="Table Name:")self.table_name_text = wx.TextCtrl(self.panel)hbox3.Add(table_name_lbl, flag=wx.ALL, border=5)hbox3.Add(self.table_name_text, proportion=1, flag=wx.EXPAND|wx.ALL, border=5)# Fields Listself.fields_panel = wx.Panel(self.panel)self.fields_sizer = wx.BoxSizer(wx.VERTICAL)self.fields_panel.SetSizer(self.fields_sizer)add_field_btn = wx.Button(self.panel, label="Add Field")add_field_btn.Bind(wx.EVT_BUTTON, self.on_add_field)# Create Buttoncreate_btn = wx.Button(self.panel, label='Create Database and Table')create_btn.Bind(wx.EVT_BUTTON, self.on_create_db)# Add to vboxvbox.Add(hbox1, flag=wx.EXPAND)vbox.Add(hbox2, flag=wx.EXPAND)vbox.Add(hbox3, flag=wx.EXPAND)vbox.Add(self.fields_panel, proportion=1, flag=wx.EXPAND|wx.ALL, border=5)vbox.Add(add_field_btn, flag=wx.ALL|wx.CENTER, border=10)vbox.Add(create_btn, flag=wx.ALL|wx.CENTER, border=10)self.panel.SetSizer(vbox)self.Centre()self.Show()def on_select_path(self, event):with wx.DirDialog(self, "Choose database save directory", "", wx.DD_DEFAULT_STYLE) as dirDialog:if dirDialog.ShowModal() == wx.ID_OK:self.db_path_text.SetValue(dirDialog.GetPath())def on_add_field(self, event):hbox = wx.BoxSizer(wx.HORIZONTAL)field_name_text = wx.TextCtrl(self.fields_panel)field_type_choice = wx.Choice(self.fields_panel, choices=["INTEGER", "TEXT", "REAL", "BLOB"])hbox.Add(field_name_text, proportion=1, flag=wx.EXPAND|wx.ALL, border=5)hbox.Add(field_type_choice, proportion=1, flag=wx.EXPAND|wx.ALL, border=5)self.fields_sizer.Add(hbox, flag=wx.EXPAND)self.fields_panel.Layout()self.panel.Layout()def on_create_db(self, event):db_path = self.db_path_text.GetValue()db_name = self.db_name_text.GetValue()table_name = self.table_name_text.GetValue()if not db_path or not db_name or not table_name:wx.MessageBox('Database path, name, and table name are required', 'Error', wx.OK | wx.ICON_ERROR)returnfields = []for hbox in self.fields_sizer.GetChildren():field_name_text = hbox.GetSizer().GetChildren()[0].GetWindow()field_type_choice = hbox.GetSizer().GetChildren()[1].GetWindow()field_name = field_name_text.GetValue()field_type = field_type_choice.GetString(field_type_choice.GetSelection())if field_name and field_type:fields.append(f"{field_name} {field_type}")if not fields:wx.MessageBox('At least one field is required', 'Error', wx.OK | wx.ICON_ERROR)returndb_full_path = os.path.join(db_path, db_name)try:conn = sqlite3.connect(db_full_path)cursor = conn.cursor()create_table_query = f"CREATE TABLE {table_name} ({', '.join(fields)})"cursor.execute(create_table_query)conn.commit()conn.close()wx.MessageBox('Database and table created successfully', 'Success', wx.OK | wx.ICON_INFORMATION)except sqlite3.Error as e:wx.MessageBox(f"An error occurred: {e}", 'Error', wx.OK | wx.ICON_ERROR)if __name__ == '__main__':app = wx.App(False)frame = SQLiteDBCreator(None, "SQLite Database Creator")app.MainLoop()

功能简介

  1. 选择数据库存放路径:通过点击“Select Path”按钮,用户可以选择数据库文件的存放目录。
  2. 设置数据库名称:用户可以输入数据库名称。
  3. 设置表名称:用户可以输入表名称。
  4. 添加字段:用户可以动态添加任意数量的字段,每个字段包含字段名称和字段类型(从下拉框中选择)。
  5. 创建数据库和表:点击“Create Database and Table”按钮,根据用户输入的信息创建 SQLite 数据库和表。

使用指南

  1. 运行程序后,首先选择数据库文件的存放路径。
  2. 输入数据库名称和表名称。
  3. 点击“Add Field”按钮添加字段,并为每个字段设置名称和类型。
  4. 添加完所有字段后,点击“Create Database and Table”按钮创建数据库和表。

结果如下:

在这里插入图片描述
在这里插入图片描述

总结

通过本篇博客介绍的代码示例,你可以轻松创建一个功能完善的 GUI 应用程序,用于动态创建 SQLite 数据库和表。这不仅提高了用户体验,还简化了数据库管理的流程。如果你有任何问题或建议,欢迎在评论区留言。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/845638.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Unity实现简单的持久化存储

在Unity中,运行过程中的内容是不会保存的,但是如果我们有些游戏数据需要持久化存储,应该怎么办呢,所以Unity为我们提供了一个简单的数据存储的API。 附上代码片段 //写入数据PlayerPrefs.SetInt("IntType", 1);PlayerPr…

FreeRTOS【13】流缓冲区使用

1.开发背景 基于以上的章节,了解了 FreeRTOS 多线程间的信号量、队列的使用,已经满足了日常使用场景。其中,队列的使用规定了队伍成员的大小,然而现实使用场景下,很多数据不都是定长大小了,例如不定长的通讯…

在AutoDL上部署Yi-34B大模型

在AutoDL上部署Yi-34B大模型 Yi介绍 Yi 系列模型是 01.AI 从零训练的下一代开源大语言模型。Yi 系列模型是一个双语语言模型,在 3T 多语言语料库上训练而成,是全球最强大的大语言模型之一。Yi 系列模型在语言认知、常识推理、阅读理解等方面表现优异。 …

一键AI抠图,证件照换背景,可部署成自己的应用

1 开发背景 AI抠图技术已经非常成熟,并且有效果非常好的开源模型。 日常中可以用于替换证件照背景 但是网上许多的证件照替换背景 竟然需要收费 鉴于此,便将目前最好的(SOTA)开源抠图模型 BRIA Background Removal v1.4 Model …

前端Vue自定义带加减按钮的数字输入框组件的设计与实现

随着前端技术的不断发展,开发的复杂度日益提升。传统的整块应用开发方式在面对小改动或小功能增加时,常常需要修改大量代码,导致整个系统的逻辑受到影响。为了解决这个问题,组件化开发成为了前端开发的必然趋势。 一、组件化开发…

GPT-4o:新一代人工智能技术的全方位解析引言

目录 🐋引言 🐋梳理 GPT 各版本之间的内容 🦈GPT-1:开创性的起点 🦈 GPT-2:参数规模的大幅提升 🦈 GPT-3:参数爆炸与多任务学习 🦈GPT-4:进一步提升的智…

pdf拆分成有图和无图的pdf(方便打印)

pdf拆分成有图和无图的pdf(方便打印) 原因 打印图片要彩印,每次都要手动弄,打印的时候很麻烦; 随着打印次数的增加,时间就越来越多 为解决此问题,使用python写一个exe解决这个问题 历程 找一个python的GUI界面找到 t…

每日刷题——杭电2156.分数矩阵和杭电2024.C语言合法标识符

杭电2156.分数矩阵 原题链接:Problem - 2156 题目描述 Problem Description:我们定义如下矩阵: 1/1 1/2 1/3 1/2 1/1 1/2 1/3 1/2 1/1 矩阵对角线上的元素始终是1/1,对角线两边分数的分母逐个递增。请求出这个矩阵的总和。 Input&#xf…

一套为家政服务行业开发的移动应用程序——家政上门服务app源码 家政上门服务系统源码

家政上门服务系统是一种通过互联网或移动应用平台,为用户提供在线预约、下单、支付和评价家政服务的系统。该系统整合了家政服务资源,使用户能够便捷地找到合适的服务人员,同时也为家政服务人员提供了更多的工作机会。 工作内容 操持家务、护…

Flink CDC - Postgres

1)部署安装Postgres服务 jiangzhongzhouZBMac-C02CW08SM ~ % docker pull postgres Using default tag: latest latest: Pulling from library/postgres latest: Pulling from library/postgres 24c63b8dcb66: Pull complete 2bb0b7dbd861: Pull complete ... D…

mac 安装java jdk8 jdk11 jdk17 等

oracle官网 https://www.oracle.com/java/technologies/downloads/ 查看当前电脑是英特尔的x86 还是arm uname -m 选择指定版本,指定平台的安装包: JDK8 JDK11的,需要当前页面往下拉: 下载到的安装包,双击安装&#x…

怎么使用Python代码在图片里面加文字

在Python中,给图片添加文字可以使用Pillow库(PIL的一个分支),它是一个强大的图像处理库。如果你还没有安装Pillow,可以通过pip安装: pip install Pillow下面使用一个简单的示例,演示如何使用Pi…

TCP的重传机制

TCP 是一个可靠的传输协议,解决了IP层的丢包、乱序、重复等问题。这其中,TCP的重传机制起到重要的作用。 序列号和确认号 之前我们在讲解TCP三次握手时,提到过TCP包头结构,其中有序列号和确认号, 而TCP 实现可靠传输…

数据分析案例一使用Python进行红酒与白酒数据数据分析

源码和数据集链接 以红葡萄酒为例 有两个样本: winequality-red.csv:红葡萄酒样本 winequality-white.csv:白葡萄酒样本 每个样本都有得分从1到10的质量评分,以及若干理化检验的结果 #理化性质字段名称1固定酸度fixed acidity2挥发性酸度volatile acidity3柠檬酸…

Lesson6--排序(初级数据结构完结篇)

【本节目标】 1. 排序的概念及其运用 2. 常见排序算法的实现 3. 排序算法复杂度及稳定性分析 1.排序的概念及其运用 1.1排序的概念 排序 :所谓排序,就是使一串记录,按照其中的某个或某些关键字的大小,递增或递减的排列起来…

Thread的stop和interrupt的区别

Thread.stop Thread.stop()方法已被废弃。 因为本质上它是不安全的,使用该方法可能会导致数据、资源不一致的问题, public class ThreadDemo {static class MyThread extends Thread {Overridepublic void run() {while (true) {try {Thread.sleep(10…

解决Windows 10通过SSH连接Ubuntu 20.04时的“Permission Denied”错误

在使用SSH连接远程服务器时,我们经常可能遇到各种连接错误,其中“Permission denied, please try again”是较为常见的一种。本文将分享一次实际案例的解决过程,帮助你理解如何排查并解决这类问题。 问题描述 在尝试从Windows 10系统通过SS…

面试题 17.05. 字母与数字(前缀和)

给定一个放有字母和数字的数组,找到最长的子数组,且包含的字母和数字的个数相同。 返回该子数组,若存在多个最长子数组,返回左端点下标值最小的子数组。若不存在这样的数组,返回一个空数组。 示例 1: 输入: ["…

openssl 常用命令demo

RSA Private Key的结构(ASN.1) RSAPrivateKey :: SEQUENCE { version Version, modulus INTEGER, -- n publicExponent INTEGER, -- e privateExponent INTEGER, -- d prime1 INTEGER, -- …

嵌入式人工智能开发:基于TensorFlow Lite和OpenCV的实时姿态估计算法实现

文章目录 引言环境准备人工智能在嵌入式系统中的应用场景代码示例常见问题及解决方案结论 1. 引言 在嵌入式系统中集成人工智能(AI)技术已经成为一种重要的发展方向。实时姿态估计是AI在嵌入式领域的一个高级应用,能够在资源受限的环境中实…