watermark logo

рдЕрдЧрд▓рд╛

рд╕реНрд╡рдд: рдкреНрд▓реЗ

Create GUI App with Tkinter and SQLite - Step by Step Python Tutorial for Beginners

1 рд╡рд┐рдЪрд╛рд░реЛрдВ тАв 10/12/24
рд╢реЗрдпрд░ рдХрд░рдирд╛
рдПрдореНрдмреЗрдб
121gamers
121gamers
14 рдЧреНрд░рд╛рд╣рдХреЛрдВ
14

Today we will create a highly sophisticated Tkinter application, which is PERFECT for beginners and even intermediate Python developers!! ЁЯТ╗ЁЯТ╗ЁЯТ╗
In this tutorial, we will:
тнР connect an SQLite database of recipes to our app.
тнР create a BEAUTIFUL graphic user interface with Tkinter.
тнР randomly shuffle recipes and display them on the app.
тнР preprocess table records.
тнР use CUSTOM FONTS with Tkinter (works with Windows only).

I will guide you step by step, explaining each command, the logic behind it and even different approaches we can take!
This tutorial is designed especially for folks who are comfortable with Python but struggle to apply it in practice. Additionally, complete Python beginners will get all the instructions they need to keep up the phase! ЁЯША

ЁЯЫСЁЯЫС Convert This App into a Professional Software ЁЯЫСЁЯЫС
-----------------------------------------------------------------------------------------------------------
Tutorial is now available (including a relational database fix!!!):
https://youtu.be/p3tSLatmGvU
-----------------------------------------------------------------------------------------------------------

Download Starter Files (and Complete Project Files):
https://github.com/MariyaSha/R....andomRecipePicker/bl

Install dependencies (Anaconda):
ЁЯРН conda install -c anaconda tk
ЁЯРН conda install -c anaconda pillow
ЁЯРН conda install -c anaconda numpy
ЁЯРН conda install -c conda-forge pyglet

Install dependencies (Pip):
ЁЯРН pip install tkinter
ЁЯРН pip install pillow
ЁЯРН pip install numpy
ЁЯРН pip install pyglet

----------------------------------------------------------
ЁЯУ╜я╕П Other Related Tutorials of Mine ЁЯУ╜я╕П
----------------------------------------------------------
тнР Install Python with Anaconda:
https://youtu.be/MUZtVEDKXsk
тнР SQLite Basics:
https://youtu.be/Ohj-CqALrwk
тнР Web Scrape Databases with SQLite and Mechanical Soup:
https://youtu.be/MkGQmZoMuRM
тнР Create simple GUI app with Tkinter:
https://youtu.be/itRLRfuL_PQ
тнР Create advanced GUI app with Tkinter:
https://youtu.be/y8PR4lTAh5E

----------------------------------------------------------
тП░TIME STAMPS тП░
----------------------------------------------------------
00:00 - intro
00:25 - starter files and wireframe
01:09 - create empty Tkinter window
01:33 - run Tkinter app
02:43 - set window title
02:58 - center window on the screen (Eval method)
04:00 - create Frame widget with custom width, height and background
05:32 - center window with Geometry method (alternative approach)
06:58 - create image widget
10:03 - center widgets in frame with pack propagate
11:01 - create Label widget
11:49 - fonts in Tkinter
13:20 - create Button widget
13:56 - change cursor to pointing hand
14:47 - button callback and why lambda is important
16:21 - add padding around widgets
17:05 - code refactoring
20:08 - connect SQLite database file
22:01 - database architecture walkthrough
23:54 - select all table names of a database with SQL
25:18 - fetch random database tables with SQL and NumPy
26:25 - fetch table records
27:56 - preprocess table name and records
30:09 - conditional list comprehension
34:45 - switch between frames
38:31 - remove widgets from frame
40:43 - sticky (remove white corners)
41:45 - label background in full window width
42:41 - use CUSTOM FONTS in Tkinter
43:24 - Pyglet
45:23 - Thanks for watching! :)

-------------------------------------------
ЁЯдЭ Connect with me ЁЯдЭ
-------------------------------------------
ЁЯФЧ Github:
https://github.com/mariyasha
ЁЯФЧ Discord:
https://discord.com/invite/wgTTmsWmXA
ЁЯФЧ LinkedIn:
https://ca.linkedin.com/in/mariyasha888
ЁЯФЧ Twitter:
https://twitter.com/mariyasha888
ЁЯФЧ Blog:
https://www.pythonsimplified.org

-------------------------------------------
ЁЯТ│ Credits ЁЯТ│
-------------------------------------------
тнР Database web scraped from:
https://cosylab.iiitd.edu.in/recipedb/
тнРSwitch between frames on StackOverflow:
https://stackoverflow.com/ques....tions/7546050/switch
тнР Beautiful icons:
flaticon.com

рдФрд░ рджрд┐рдЦрд╛рдУ
0 рдЯрд┐рдкреНрдкрдгрд┐рдпрд╛рдБ sort рдЗрд╕рдХреЗ рдЕрдиреБрд╕рд╛рд░ рдХреНрд░рдордмрджреНрдз рдХрд░реЗрдВ
рдлреЗрд╕рдмреБрдХ рдЯрд┐рдкреНрдкрдгрд┐рдпрд╛рдБ

рдЕрдЧрд▓рд╛

рд╕реНрд╡рдд: рдкреНрд▓реЗ