电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

python制作一個簡單的gui 數據庫查詢界面

瀏覽:2日期:2022-07-04 18:37:05

一、準備工作:

1、安裝mysql3.7,創建一個test數據庫,創建student表,創建列:(列名看代碼),創建幾條數據

(以上工作直接用navicat for mysql工具完成)

二、代碼:

import sysimport tkinter as tkimport mysql.connector as sql#--------------------查詢函數---------------------------def sql_connect(): listbox_show.delete(0,’end’) #初始化清空顯示區 m = listbox_name.curselection()[0] print(’m=’,m) list_name = listbox_name.get(m)[0] varlue = entry_varlue.get() print(’list_name=’,list_name) print(’var=’,varlue) while list_name == ’Student_ID’: sql_sr = 'select * from Student where student.student_id = ' + '’' + varlue +'’' print(sql_sr) break while list_name == ’Name’: sql_sr = 'select * from Student where student.name = ' + '’' + varlue +'’' print(sql_sr) break while list_name == ’Age’: sql_sr = 'select * from Student where student.age = ' + '’' + varlue +'’' print(sql_sr) break while list_name == ’Sex’: sql_sr = 'select * from Student where student.sex = ' + '’' + varlue +'’' print(sql_sr) break while list_name == ’Class’: sql_sr = 'select * from Student where student.class = ' + '’' + varlue +'’' print(sql_sr) break mydb = sql.connect(host=’localhost’,user=’root’,passwd=’123456’,database=’test’) mycursor = mydb.cursor() mycursor.execute(sql_sr) myresult = mycursor.fetchall() for x in myresult: print (x) listbox_show.insert(’end’,x)#--------------------------------------------------------#------------界面初始化時加載選項列表--------------------sql_n = 'SELECT COLUMN_NAME FROM information_schema.COLUMNS WHERE TABLE_SCHEMA = ’test’ AND TABLE_NAME = ’student’'mydb = sql.connect(host=’localhost’,user=’root’,passwd=’123456’,database=’test’)mycursor = mydb.cursor()mycursor.execute(sql_n)myresult = mycursor.fetchall()#--------------------------------------------------------#----------窗體部分--------------------------------------entry_list_name = tk.Entry()entry_list_name.pack()listbox_name = tk.Listbox()listbox_name.pack()for i in myresult: listbox_name.insert(’end’,i) #加載選項列表entry_varlue = tk.Entry()entry_varlue.pack()button_select = tk.Button(text = ’查找’,command = sql_connect)button_select.pack()listbox_show = tk.Listbox()listbox_show.pack()root.mainloop()#--------------------------------------------------------

三、界面

python制作一個簡單的gui 數據庫查詢界面

好吧,是挺丑的,因為沒調格式,將就吧。

四、總結

1、目的:自己這個菜鳥新手天天看基礎教程覺得很抽象,各種運算結果只能打印在IDE窗口,不是我想象中的程序(有界面,有交互,有。。。總之很精彩),然后按教程的各種漸進學法感覺不太適合自己的風格,我喜歡有一個具體的東西,不斷的添加功能,然后在添加的過程中碰到問題再尋求解決辦法,在解決的過程中學習新知識,嗯,就是只學能用到的,很功利。。。然后就開始折騰這個小界面。

2、首先要有GUI界面就要用到GUI模塊,本著方便原則就用python自帶的tkinter(不用再折騰安裝),一開始我想用所見即所得的方式,找到了一個可以拖放元件來生成界面的工具page python,這也是個基于tkinter的工具,后來發現生成的py文件對我這個菜鳥來說還是有點深奧了,而且關于page的教程全網只有一兩個(無語,估計高手都不屑吧),然后就轉而直接研究tkinter

3、先做好窗體部分的實現代碼。

設計:按動按鈕查詢固定表里某一字段的某個匹配值的結果,顯示在界面中。

元件:輸入元件2個(1個字段,1個值),結果顯示元件1個,按鈕1個。

字段輸入值直接獲取表頭列出選擇,找不到下拉菜單,只能用listbox來做,界面初始化時就將表頭讀出列在listbox里。

匹配值輸入使用entry輸入框。

顯示結果也是使用listbox。

交互動作使用按鈕。

OK,視覺界面做好了,下面添加功能。

4、(字段輸入值直接獲取表頭列出選擇,找不到下拉菜單,只能用listbox來做,界面初始化時就將表頭讀出列在listbox里。)

要和mysql交互獲取,需要登錄數據庫并實現查詢。

我使用import mysql.connector模塊來實現和mysql的通訊(python還有期它模塊也能實現和mysql的通訊,當時為什么使用mysql.connector呢,我也記不清了,好像從哪個教程直接弄來用的,反正就是用了)

于是又去啃了sql的查詢語句,這里還是挺齊全的https://www.runoob.com/sql/sql-select.html,不過我是沒學全的,沒辦法,學渣只能用到哪學到哪。重點說一下,sql語句里的 + 號就是將前后的值串起來,可以理解為and。可以將字符和變量串起來。

5、接下來就是按鈕動作的交互代碼了,這是邏輯的重頭戲。

邏輯:在列出的字段中選擇一個要查詢的字段,輸入要匹配的值,點擊按鈕查詢,將結果顯示在顯示區。

獲取listbox的光標值,將它取出來,比對字段生成相應的sql查詢語句,和mysql交互得到返回值集,逐條取出展示在顯示區。

好了,大功告成,雖然看起來很丑,想讓它變美女就要加濾鏡咯(調tkinter格式)。

以上就是python制作一個簡單的gui 數據庫查詢界面的詳細內容,更多關于python gui數據庫查詢的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 展厅装修公司|企业展厅设计|展厅制作|展厅搭建—广州展厅装饰公司 | 吨袋包装机|吨包秤|吨包机|集装袋包装机-烟台华恩科技 | 齿轮减速马达一体式_蜗轮蜗杆减速机配电机-德国BOSERL齿轮减速电动机生产厂家 | 六维力传感器_三维力传感器_二维力传感器-南京神源生智能科技有限公司 | 压片机_高速_单冲_双层_花篮式_多功能旋转压片机-上海天九压片机厂家 | 全自动实验室洗瓶机,移液管|培养皿|进样瓶清洗机,清洗剂-广州摩特伟希尔机械设备有限责任公司 | 纯化水设备-纯水设备-超纯水设备-[大鹏水处理]纯水设备一站式服务商-东莞市大鹏水处理科技有限公司 | 黑田精工电磁阀-CAMMOZI气缸-ROSS电磁-上海茂硕机械设备有限公司 | 西门子气候补偿器,锅炉气候补偿器-陕西沃信机电工程有限公司 | hdpe土工膜-防渗膜-复合土工膜-长丝土工布价格-厂家直销「恒阳新材料」-山东恒阳新材料有限公司 ETFE膜结构_PTFE膜结构_空间钢结构_膜结构_张拉膜_浙江萬豪空间结构集团有限公司 | 散热器厂家_暖气片_米德尔顿散热器 | 曙光腾达官网-天津脚手架租赁-木板架出租-移动门式脚手架租赁「免费搭设」 | 优秀的临床医学知识库,临床知识库,医疗知识库,满足电子病历四级要求,免费试用 | 选矿设备-新型重选设备-金属矿尾矿重选-青州冠诚重工机械有限公司 | 微波消解仪器_智能微波消解仪报价_高压微波消解仪厂家_那艾 | 编织人生 - 权威手工编织网站,编织爱好者学习毛衣编织的门户网站,织毛衣就上编织人生网-编织人生 | pbt头梳丝_牙刷丝_尼龙毛刷丝_PP塑料纤维合成毛丝定制厂_广州明旺 | 模型公司_模型制作_沙盘模型报价-中国模型网 | 裹包机|裹膜机|缠膜机|绕膜机-上海晏陵智能设备有限公司 | 福尔卡(北京)新型材料技术股份有限公司| 生产自动包装秤_颗粒包装秤_肥料包装秤等包装机械-郑州鑫晟重工科技有限公司 | 通风天窗,通风气楼,屋顶通风天窗,屋顶通风天窗公司 | 无锡门窗-系统门窗-阳光房-封阳台-断桥铝门窗厂[窗致美] | 钢格板|镀锌钢格板|热镀锌钢格板|格栅板|钢格板|钢格栅板|热浸锌钢格板|平台钢格板|镀锌钢格栅板|热镀锌钢格栅板|平台钢格栅板|不锈钢钢格栅板 - 专业钢格板厂家 | 大倾角皮带机-皮带输送机-螺旋输送机-矿用皮带输送机价格厂家-河南坤威机械 | 刑事律师_深圳著名刑事辩护律师_王平聚【清华博士|刑法教授】 | 爱佩恒温恒湿测试箱|高低温实验箱|高低温冲击试验箱|冷热冲击试验箱-您身边的模拟环境试验设备技术专家-合作热线:400-6727-800-广东爱佩试验设备有限公司 | 胶原检测试剂盒,弹性蛋白检测试剂盒,类克ELISA试剂盒,阿达木单抗ELISA试剂盒-北京群晓科苑生物技术有限公司 | 伸缩节_伸缩器_传力接头_伸缩接头_巩义市联通管道厂 | 智能案卷柜_卷宗柜_钥匙柜_文件流转柜_装备柜_浙江福源智能科技有限公司 | 水冷散热器_水冷电子散热器_大功率散热器_水冷板散热器厂家-河源市恒光辉散热器有限公司 | 锡膏喷印机-全自动涂覆机厂家-全自动点胶机-视觉点胶机-深圳市博明智控科技有限公司 | 带式过滤机厂家_价格_型号规格参数-江西核威环保科技有限公司 | 自动螺旋上料机厂家价格-斗式提升机定制-螺杆绞龙输送机-杰凯上料机 | 篷房|仓储篷房|铝合金篷房|体育篷房|篷房厂家-华烨建筑科技官网 知名电动蝶阀,电动球阀,气动蝶阀,气动球阀生产厂家|价格透明-【固菲阀门官网】 | 实验室pH计|电导率仪|溶解氧测定仪|离子浓度计|多参数水质分析仪|pH电极-上海般特仪器有限公司 | 干式磁选机_湿式磁选机_粉体除铁器-潍坊国铭矿山设备有限公司 | 智慧食堂_食堂管理系统_食堂订餐_食堂消费系统—客易捷 | 西门子伺服控制器维修-伺服驱动放大器-828D数控机床维修-上海涌迪 | 私人别墅家庭影院系统_家庭影院音响_家庭影院装修设计公司-邦牛影音 | LED灯杆屏_LED广告机_户外LED广告机_智慧灯杆_智慧路灯-太龙智显科技(深圳)有限公司 |