Skip to content
View PySimpleGUI's full-sized avatar
🧡
Having the time of my life hearing from so many happy people! 💖
🧡
Having the time of my life hearing from so many happy people! 💖

Sponsors

@eagleEggs
Private Sponsor
@KarlRW
@Kazuhito00
@ngc6309
@NS-sasaki
@hoffstadt
Private Sponsor
@israel-dryer
@rootisgod
@yyolk
@rowlesmr
Private Sponsor

Highlights

  • Pro
Block or Report

Block or report PySimpleGUI

Block user

Prevent this user from interacting with your repositories and sending you notifications. Learn more about blocking users.

You must be logged in to block users.

Add an optional note:
Please don't include any personal information such as legal names or email addresses. Maximum 100 characters, markdown supported. This note will be visible to only you.
Report abuse

Contact GitHub support about this user’s behavior. Learn more about reporting abuse.

Report abuse
PySimpleGUI/readme.md

User Interfaces for Humans

User Interfaces for HumansTM

PySimpleGUI Udemy Course
apply coupon for discount:
522B20BF5EF123C4AB30
click here to visit course page

Transforms the tkinter, Qt, WxPython, and Remi (browser-based) GUI frameworks into a simpler interface. The window definition is simplified by using Python core data types understood by beginners (lists and dictionaries). Further simplification happens by changing event handling from a callback-based model to a message passing one.

Your code is not required to have an object oriented architecture which makes the package usable by a larger audience. While the architecture is simple to understand, it does not necessarily limit you to only simple problems.

Some programs are not well-suited for PySimpleGUI however. By definition, PySimpleGUI implements a subset of the underlying GUI frameworks' capabilities. It's difficult to define exactly which programs are well suited for PySimpleGUI and which are not. It depends on the details of your program. Duplicating Excel in every detail is an example of something not well suited for PySimpleGUI.

Japanese version of this readme.

PySimpleGUI needs your support. If you find PySimpleGUI useful, please consider sponsoring the project on GitHub or BuyMeACoffee. It's expensive working full-time on PySimpleGUI and also paying for ongoing expenses (domains, artists, software, consultants, sponsoring open source projects).

Buy Me A Coffee


Statistics 📈

PyPI Statistics & Versions

TK TK 2.7 Qt WxPython Web (Remi)
tkinter tkinter 2.7 downloads qt wx web
tkinter tkinter27 Downloads Downloads Downloads
tkinter tkinter 2.7 qt wx web
PyPI pyversions PyPI pyversions PyPI pyversions PyPI pyversions PyPI pyversions

GitHub Statistics

Issues Commit Activity Stars Docs
GitHub issues commit activity stars Documentation Status
GitHub closed issues last commit


What Is PySimpleGUI ❓

PySimpleGUI is a Python package that enables Python programmers of all levels to create GUIs. You specify your GUI window using a "layout" which contains widgets (they're called "Elements" in PySimpleGUI). Your layout is used to create a window using one of the 4 supported frameworks to display and interact with your window. Supported frameworks include tkinter, Qt, WxPython, or Remi. The term "wrapper" is sometimes used for these kinds of packages.

Your PySimpleGUI code is simpler and shorter than writing directly using the underlying framework because PySimpleGUI implements much of the "boilerplate code" for you. Additionally, interfaces are simplified to require as little code as possible to get the desired result. Depending on the program and framework used, a PySimpleGUI program may require 1/2 to 1/10th amount of code to create an identical window using one of the frameworks directly.

While the goal is to encapsulate/hide the specific objects and code used by the GUI framework you are running on top of, if needed you can access the frameworks' dependent widgets and windows directly. If a setting or feature is not yet exposed or accessible using the PySimpleGUI APIs, you are not walled off from the framework. You can expand capabilities without directly modifying the PySimpleGUI package itself.

Bridging the "GUI Gap"

Python has brought a large number of people into the programming community. The number of programs and the range of areas it touches is mindboggling. But more often than not, these technologies are out of reach of all but a handful of people. The majority of Python programs are "command line" based. This isn't a problem for programmer-types as we're all used to interacting with computers through a text interface. While programmers don't have a problem with command-line interfaces, most "normal people" do. This creates a digital divide, a "GUI Gap".

Adding a GUI to a program opens that program up to a wider audience. It becomes more approachable. GUIs can also make interacting with some programs easier, even for those that are comfortable with a command-line interface. And finally, some problems require a GUI.

Recognition of Open Source Use

In the Demo Programs or one of the PySimpleGUI Account's Repos these packages were used at least one time. Some of your are the goodies on the right of the GUI gap.

If you use Open Source software in your project, be sure and supply information about the packages you used.

  • chatterbot
  • cv2
  • fitz
  • forecastio
  • gtts
  • matplotlib
  • mido
  • mpl_toolkits
  • notifypy
  • numpy
  • pandas
  • PIL
  • praw
  • psgtray
  • psutil
  • pyfiglet
  • pygame
  • pylab
  • pymunk
  • requests
  • vlc
  • win32api
  • win32con
  • win32gui
  • win32process

LPLG3 as an Example

The licensing terms in the LLC3 Licensing, it states:

  1. Combined Works. You may convey a Combined Work under terms of your choice that, taken together, effectively do not restrict modification of the portions of the Library contained in the Combined Work and reverse engineering for debugging such modifications, if you also do each of the following:

a) Give prominent notice with each copy of the Combined Work that the Library is used in it and that the Library and its use are covered by this License.

b) Accompany the Combined Work with a copy of the GNU GPL and this license document.

Since the above packages each have a similar license clause, I'm listing them here, in what I would consider a "prominent notice" location, that I'm using the fine works of these groups or individuals. They are used in the Demo Programs most likely or one of the Repos that are under this account as this list is all inclusive.

You all have my respect and admiration. You're enabling bigger things. What a special kind of thing to make. Who knows what you've enabled. I believe more people are getting over to your creations and getting to experience them.

tkinter team - PySimpleGUI would be nowhere without your lengthy work & continuous dedication. ONE GUI API for 3 different OS's? Really? With no code changes to move between? That's a huge accomplishment. You're #1 to me. Thank you for your hard work.

Getting Over "The Bar"

It's been said by some that "the bar is pretty high" when it comes to learning GUI programming in Python.

What happens when the bar is placed on the ground and can be stepped over?

This is one of the questions that the PySimpleGUI project has tried to answer. Here's a humorous look at what's been a not funny situation.

The results have been fascinating to witness and it's been touching to read the accounts of the journeys of users.

Nothing prepared me for the emails that started to arrive soon after the first release of PySimpleGUI. They are heartwarming and heartbreaking tales of life-long dreams of creating a program that required a GUI. Some made a few attempts, giving up each time. Others never started once they started to research what was required.

After recounting the varied and long road to finding PySimpleGUI, the stories became similar. They each found success and expressed joy and gratitude. The joy expressed in these messages was unlike anything I had encountered in the entirety of career in the computing field.

It's been these emails and the messages of gratitude seen here in the GitHub Issues that made dedicating my life to his project a non-decision.


Subscribing to Announcements 📢

If you click the "Subscribe" button in the Announcements GitHub Issue, then you'll be notified when project news is published. This Issue is the official location to get the latest PySimpleGUI information. Information is posted frequently including release contents, tips & tricks, documentation updates, etc. There have been over 1,000 posts since the project started.


About Me 👋

Hi there! I'm Mike. You'll find me right here, on the PySimpleGUI GitHub, solving problems and continuously pushing PySimpleGUI forward. I've dedicated my days, nights, and weekends to the project and PySimpleGUI users. Our successes are ultimately shared. I'm successful when you're successful.

While I'm a relative newcomer to Python, I've been writing software since the 70s. The majority of my career was spent creating products in Silicon Valley. I bring to PySimpleGUI the same professionalism and dedication as I did to the corporate products I developed. You are my customers now.

Project Goals 🥅

Two of the most important goals of the PySimpleGUI project:

  • Having fun
  • Your success

Fun as a goal on a serious project sounds odd, but it's a serious goal. I find writing these GUI programs to be a lot of fun. One reason is how little time it takes to write a complete solution. If we're not enjoying the process then someone's going to give up.

There is a significant amount of documentation, a cookbook, 100's of demo programs to get you immediately running, a detailed call reference, YouTube videos, online Trinket demos, and more... all working to create... a fun experience.

Your Success is a shared goal. PySimpleGUI was built for developers. You're my peeps. It's been an unexpected reward to see the results of the combined effort of users and PySimpleGUI. Use the documentation & other materials to help build your application. If you run into trouble, help is available by opening on Issue on the PySimpleGUI GitHub. Take a look at the section on Support below.


Educational Resources 📚

PySimpleGUI now has an official Udemy course! Check the header of this readme and the PySimpleGUI documentation for a coupon code. The course can be found at www.udemy.com/PySimpleGUI. This course is currently the only income source for the PySimpleGUI project other than sponsorships and donations.

www.PySimpleGUI.org is easy to remember and is where the documentation is located. You'll find tabs across the top that represent several different documents. The documentation is located on "Read The Docs" so that there is a table of contents for each document and they are easy to search.

There are 100s of pages of written documentation and 100s of example programs that will help you be effective very quickly. Rather than requiring days or weeks of investment to learn a single GUI package, you may be able to complete your project in a single afternoon when using PySimpleGUI.

Example 1 - The One-Shot Window

This type of program is called a "one-shot" window because the window is displayed one time, the values collected, and then it is closed. It doesn't remain open for a long time like you would in a Word Processor.

Anatomy of a Simple PySimpleGUI Program

There are 5 sections to a PySimpleGUI program

import PySimpleGUI as sg                        # Part 1 - The import

# Define the window's contents
layout = [  [sg.Text("What's your name?")],     # Part 2 - The Layout
            [sg.Input()],
            [sg.Button('Ok')] ]

# Create the window
window = sg.Window('Window Title', layout)      # Part 3 - Window Defintion
                                                
# Display and interact with the Window
event, values = window.read()                   # Part 4 - Event loop or Window.read call

# Do something with the information gathered
print('Hello', values[0], "! Thanks for trying PySimpleGUI")

# Finish up by removing from the screen
window.close()                                  # Part 5 - Close the Window

The code produces this window


Example 2 - Interactive Window

In this example, our window will remain on the screen until the user closes the window or clicks the Quit button. The main difference between the one-shot window you saw earlier and an interactive window is the addition of an "Event Loop". The Event Loop reads events and inputs from your window. The heart of your application lives in the event loop.

import PySimpleGUI as sg

# Define the window's contents
layout = [[sg.Text("What's your name?")],
          [sg.Input(key='-INPUT-')],
          [sg.Text(size=(40,1), key='-OUTPUT-')],
          [sg.Button('Ok'), sg.Button('Quit')]]

# Create the window
window = sg.Window('Window Title', layout)

# Display and interact with the Window using an Event Loop
while True:
    event, values = window.read()
    # See if user wants to quit or window was closed
    if event == sg.WINDOW_CLOSED or event == 'Quit':
        break
    # Output a message to the window
    window['-OUTPUT-'].update('Hello ' + values['-INPUT-'] + "! Thanks for trying PySimpleGUI")

# Finish up by removing from the screen
window.close()

This is the window that Example 2 produces.

And here's what it looks like after you enter a value into the Input field and click the Ok button.

Let's take a quick look at some of the differences between this example and the one-shot window.

First, you'll notice differences in the layout. Two changes in particular are important. One is the addition of the key parameter to the Input element and one of the Text elements. A key is like a name for an element. Or, in Python terms, it's like a dictionary key. The Input element's key will be used as a dictionary key later in the code.

Another difference is the addition of this Text element:

          [sg.Text(size=(40,1), key='-OUTPUT-')],

There are 2 parameters, the key we already covered. The size parameter defines the size of the element in characters. In this case, we're indicating that this Text element is 40 characters wide, by 1 character high. Notice that there is no text string specified which means it'll be blank. You can easily see this blank row in the window that's created.

We also added a button, "Quit".

The Event Loop has our familiar window.read() call.

Following the read is this if statement:

    if event == sg.WINDOW_CLOSED or event == 'Quit':
        break

This code is checking to see if the user closed the window by clicking the "X" or if they clicked the "Quit" button. If either of these happens, then the code will break out of the event loop.

If the window wasn't closed nor the Quit button clicked, then execution continues. The only thing that could have happened is the user clicked the "Ok" button. The last statement in the Event Loop is this one:

    window['-OUTPUT-'].update('Hello ' + values['-INPUT-'] + "! Thanks for trying PySimpleGUI")

This statement updates the Text element that has the key -OUTPUT- with a string. window['-OUTPUT-'] finds the element with the key -OUTPUT-. That key belongs to our blank Text element. Once that element is returned from the lookup, then its update method is called. Nearly all elements have an update method. This method is used to change the value of the element or to change some configuration of the element.

If we wanted the text to be yellow, then that can be accomplished by adding a text_color parameter to the update method so that it reads:

    window['-OUTPUT-'].update('Hello ' + values['-INPUT-'] + "! Thanks for trying PySimpleGUI",
                              text_color='yellow')

After adding the text_color parameter, this is our new resulting window:

The parameters available for each element are documented in both the call reference documentation as well as the docstrings. PySimpleGUI has extensive documentation to help you understand all of the options available to you. If you lookup the update method for the Text element, you'll find this definition for the call:

As you can see several things can be changed for a Text element. The call reference documentation is a valuable resource that will make programming in PySimpleGUI, uhm, simple.


Jump Start! Get the Demo Programs & Demo Browser 🔎

The over 300 Demo Programs will give you a jump-start and provide many design patterns for you to learn how to use PySimpleGUI and how to integrate PySimpleGUI with other packages. By far the best way to experience these demos is using the Demo Browser. This tool enables you to search, edit and run the Demo Programs.

To get them installed quickly along with the Demo Browser, use pip to install psgdemos:

python -m pip install psgdemos

or if you're in Linux, Mac, etc, that uses python3 instead of python to launch Python:

python3 -m pip install psgdemos

Once installed, launch the demo browser by typing psgdemos from the command line"

psgdemos

SNAG-1543


Layouts Are Funny LOL! 😆

Your window's layout is a "list of lists" (LOL). Windows are broken down into "rows". Each row in your window becomes a list in your layout. Concatenate together all of the lists and you've got a layout...a list of lists.

Here is the same layout as before with an extra Text element added to each row so that you can more easily see how rows are defined:

layout = [  [sg.Text('Row 1'), sg.Text("What's your name?")],
            [sg.Text('Row 2'), sg.Input()],
            [sg.Text('Row 3'), sg.Button('Ok')] ]

Each row of this layout is a list of elements that will be displayed on that row in your window.

Using lists to define your GUI has some huge advantages over how GUI programming is done using other frameworks. For example, you can use Python's list comprehension to create a grid of buttons in a single line of code.

These 3 lines of code:

import PySimpleGUI as sg

layout = [[sg.Button(f'{row}, {col}') for col in range(4)] for row in range(4)]

event, values = sg.Window('List Comprehensions', layout).read(close=True)

produces this window which has a 4 x 4 grid of buttons:

Recall how "fun" is one of the goals of the project. It's fun to directly apply Python's powerful basic capabilities to GUI problems. Instead of pages of code to create a GUI, it's a few (or often 1) lines of code.

Collapsing Code

It's possible to condense a window's code down to a single line of code. The layout definition, window creation, display, and data collection can all be written in this line of code:

event, values = sg.Window('Window Title', [[sg.Text("What's your name?")],[sg.Input()],[sg.Button('Ok')]]).read(close=True)

The same window is shown and returns the same values as the example showing the sections of a PySimpleGUI program. Being able to do so much with so little enables you to quickly and easily add GUIs to your Python code. If you want to display some data and get a choice from your user, it can be done in a line of code instead of a page of code.

By using short-hand aliases, you can save even more space in your code by using fewer characters. All of the Elements have one or more shorter names that can be used. For example, the Text element can be written simply as T. The Input element can be written as I and the Button as B. Your single-line window code thus becomes:

event, values = sg.Window('Window Title', [[sg.T("What's your name?")],[sg.I()],[sg.B('Ok')]]).read(close=True)

Code Portability

PySimpleGUI is currently capable of running on 4 Python GUI Frameworks. The framework to use is specified using the import statement. Change the import and you'll change the underlying GUI framework. For some programs, no other changes are needed than the import statement to run on a different GUI framework. In the example above, changing the import from PySimpleGUI to PySimpleGUIQt, PySimpleGUIWx, PySimpleGUIWeb will change the framework.

Import Statement Resulting Window
PySimpleGUI
PySimpleGUIQt
PySimpleGUIWx
PySimpleGUIWeb

Porting GUI code from one framework to another (e.g. moving your code from tkinter to Qt) usually requires a rewrite of your code. PySimpleGUI is designed to enable you to have easy movement between the frameworks. Sometimes some changes are required of you, but the goal is to have highly portable code with minimal changes.

Some features, like a System Tray Icon, are not available on all of the ports. The System Tray Icon feature is available on the Qt and WxPython ports. A simulated version is available on tkinter. There is no support for a System Tray icon in the PySimpleGUIWeb port.

Runtime Environments

Environment Supported
Python Python 3.4+
Operating Systems Windows, Linux, Mac
Hardware Desktop PCs, Laptops, Raspberry Pi, Android devices running PyDroid3
Online repli.it, Trinket.com (both run tkinter in a browser)
GUI Frameworks tkinter, pyside2, WxPython, Remi

Integrations

Among the more than 200 "Demo Programs", you'll find examples of how to integrate many popular Python packages into your GUI.

Want to embed a Matplotlib drawing into your window? No problem, copy the demo code and instantly have a Matplotlib drawing of your dreams into your GUI.

These packages and more are ready for you to put into your GUI as there are demo programs or a demo repo available for each:

Package Description
Matplotlib Many types of graphs and plots
OpenCV Computer Vision (often used for AI)
VLC Video playback
pymunk Physics engine
psutil System environment statistics
prawn Reddit API
json PySimpleGUI wraps a special API to store "User Settings"
weather Integrates with several weather APIs to make weather apps
mido MIDI playback
beautiful soup Web Scraping (GitHub issue watcher example)

Installing 💾

Two common ways of installing PySimpleGUI:

  1. pip to install from PyPI
  2. Download the file PySimpleGUI.py and place in your application's folder

Pip Installing & Upgrading

The current suggested way of invoking the pip command is by running it as a module using Python. Previously the command pip or pip3 was directly onto a command-line / shell. The suggested way

Initial install for Windows:

python -m pip install PySimpleGUI

Initial install for Linux and MacOS:

python3 -m pip install PySimpleGUI

To upgrade using pip, you simply add 2 parameters to the line --upgrade --no-cache-dir.

Upgrade installation on Windows:

python -m pip install --upgrade --no-cache-dir PySimpleGUI

Upgrade for Linux and MacOS:

python3 -m pip install --upgrade --no-cache-dir PySimpleGUI

Single File Installing

PySimpleGUI was created as a single .py file so that it would be very easy for you to install it, even on systems that are not connected to the internet like a Raspberry Pi. It's as simple as placing the PySimpleGUI.py file into the same folder as your application that imports it. Python will use your local copy when performing the import.

When installing using just the .py file, you can get it from either PyPI or if you want to run the most recent unreleased version then you'll download it from GitHub.

To install from PyPI, download either the wheel or the .gz file and unzip the file. If you rename the .whl file to .zip you can open it just like any normal zip file. You will find the PySimpleGUI.py file in one of the folders. Copy this file to your application's folder and you're done.

The PyPI link for the tkinter version of PySimpleGUI is: https://pypi.org/project/PySimpleGUI/#files

The GitHub repo's latest version can be found here: https://raw.githubusercontent.com/PySimpleGUI/PySimpleGUI/master/PySimpleGUI.py

Now some of you are thinking, "yea, but, wait, having a single huge source file is a terrible idea". And, yea, sometimes it can be a terrible idea. In this case, the benefits greatly outweighed the downside. Lots of concepts in computer science are tradeoffs or subjective. As much as some would like it to be, not everything is black and white. Many times the answer to a question is "it depends".

Galleries 🎨

Work on a more formal gallery of user-submitted GUIs as well as those found on GitHub is underway but as of this writing it's not complete. There are currently 2 places you can go to see some screenshots in a centralized way. Hopefully, a Wiki or other mechanism can be released soon to do justice to the awesome creations people are making.

User Submitted Gallery

The first is a user submitted screenshots issue located on the GitHub. It's an informal way for people to show off what they've made. It's not ideal, but it was a start.

Massive Scraped GitHub Images

The second is a massive gallery of over 3,000 images scraped from 1,000 projects on GitHub that are reportedly using PySimpleGUI. It's not been hand-filtered and there are plenty of old screenshots that were used in the early documentation. But, you may find something in there that sparks your imagination.


Uses for PySimpleGUI 🔨

The following sections showcase a fraction of the uses for PySimpleGUI. There are over 1,000 projects on GitHub alone that use PySimpleGUI. It's truly amazing how possibilities have opened up for so many people. Many users have spoken about previously attempting to create a GUI in Python and failing, but finally achieving their dreams when they tried PySimpleGUI.

Your First GUI

Of course one of the best uses of PySimpleGUI is getting you into making GUIs for your Python projects. You can start as small as requesting a filename. For this, you only need to make a single call to one of the "high-level functions" called popup. There are all kinds of popups, some collect information.

popup on itself makes a window to display information. You can pass multiple parameters just like a print. If you want to get information, then you will call functions that start with popup_get_ such as popup_get_filename.

Adding a single line to get a filename instead of specifying a filename on the command line can transform your program into one that "normal people" will feel comfortable using.

import PySimpleGUI as sg

filename = sg.popup_get_file('Enter the file you wish to process')
sg.popup('You entered', filename)

This code will display 2 popup windows. One to get the filename, which can be browsed to or pasted into the input box.

img

The other window will output what is collected.

img


Rainmeter-Style Windows

img The default settings for GUI frameworks don't tend to produce the nicest looking windows. However, with some attention to detail, you can do several things to make windows look attractive. PySimpleGUI makes it easier to manipulate colors and features like removing the title bar. The result is windows that don't look like your typical tkinter windows.

Here is an example of how you can create windows that don't look like your typical tkinter in windows. In this example, the windows have their titlebars removed. The result is windows that look much like those found when using Rainmeter, a desktop widget program.



You can easily set the transparency of a window as well. Here are more examples of desktop widgets in the same Rainmeter style. Some are dim appearing because they are semi-transparent. img

Both of these effects; removing the titlebar and making a window semi-transparent, are achieved by setting 2 parameters when creating the window. This is an example of how PySimpleGUI enables easy access to features. And because PySimpleGUI code is portable across the GUI frameworks, these same parameters work for the other ports such as Qt.

Changing the Window creation call in Example 1 to this line of code produces a similar semi-transparent window:

window = sg.Window('My window', layout, no_titlebar=True, alpha_channel=0.5)

Games

While not specifically written as a game development SDK, PySimpleGUI makes the development of some games quite easy.

img This Chess program not only plays chess, but it integrates with the Stockfish chess-playing AI.










img Several variants of Minesweeper have been released by users.










img









img

Card games work well with PySimpleGUI as manipulating images is simple when using the PySimpleGUI Graph element.

While not specifically written as a game development SDK, PySimpleGUI makes development of some games quite easy.






Media Capture and Playback

img

Capturing and displaying video from your webcam in a GUI is 4 lines of PySimpleGUI code. Even more impressive is that these 4 lines of code work with the tkinter, Qt, and Web ports. You can display your webcam, in realtime, in a browser using the same code that displays the image using tkinter.

Media playback, audio and video, can also be achieved using the VLC player. A demo application is provided to you so that you have a working example to start from. Everything you see in this readme is available to you as a starting point for your own creations.











Artificial Intelligence

img

AI and Python have long been a recognized superpower when the two are paired together. What's often missing however is a way for users to interact with these AI algorithms familiarly, using a GUI.

These YOLO demos are a great example of how a GUI can make a tremendous difference in interacting with AI algorithms. Notice two sliders at the bottom of these windows. These 2 sliders change a couple of the parameters used by the YOLO algorithm.

If you were tuning your YOLO demo using only the command line, you would need to set the parameters, once, when you launch the application, see how they perform, stop the application, change the parameters, and finally restart the application with the new parameters.



img

Contrast those steps against what can be done using a GUI. A GUI enables you to modify these parameters in real-time. You can immediately get feedback on how they are affecting the algorithm.








img

There are SO many AI programs that have been published that are command-line driven. This in itself isn't a huge hurdle, but it's enough of a "pain in the ass" to type/paste the filename you want to colorize on the command line, run the program, then open the resulting output file in a file viewer.

GUIs have the power to change the user experience, to fill the "GUI Gap". With this colorizer example, the user only needs to supply a folder full of images, and then click on an image to both colorize and display the result.

The program/algorithm to do the colorization was freely available, ready to use. What was missing is the ease of use that a GUI could bring.


Graphing

img

Displaying and interacting with data in a GUI is simple with PySimpleGUI. You have several options.

You can use the built-in drawing/graphing capabilities to produce custom graphs. This CPU usage monitor uses the Graph element





img

Matplotlib is a popular choice with Python users. PySimpleGUI can enable you to embed Matplotlib graphs directly into your GUI window. You can even embed the interactive controls into your window if you want to retain the Matplotlib interactive features.









img Using PySimpleGUI's color themes, you can produce graphs that are a notch above default graphs that most people create in Matplotlib.
















Front-ends

img

The "GUI Gap" mentioned earlier can be easily solved using PySimpleGUI. You don't even need to have the source code to the program you wish to add a GUI onto. A "front-end" GUI is one that collects information that is then passed to a command-line application.

Front-end GUIs are a fantastic way for a programmer to distribute an application that users were reluctant to use previously because they didn't feel comfortable using a command-line interface. These GUIs are your only choice for command-line programs that you don't have access to the source code for.

This example is a front-end for a program called "Jump Cutter". The parameters are collected via the GUI, a command-line is constructed using those parameters, and then the command is executed with the output from the command-line program being routed to the GUI interface. In this example, you can see in yellow the command that was executed.


Raspberry Pi

img

Because PySimpleGUI is compatible back to Python 3.4, it is capable of creating a GUI for your Raspberry Pi projects. It works particularly well when paired with a touchscreen. You can also use PySimpleGUIWeb to control your Pi if it doesn't have a monitor attached.











Easy Access to Advanced Features

img

Because it's very easy to access many of the underlying GUI frameworks' features, it's possible to piece together capabilities to create applications that look nothing like those produced using the GUI framework directly.

For example, it's not possible to change the color/look-and-feel of a titlebar using tkinter or the other GUI packages, but with PySimpleGUI it's easy to create windows that appear as if they have a custom titlebar.


img

Unbelievably, this window is using tkinter to achieve what appears to be something like a screensaver.

On windows, tkinter can completely remove the background from your application. Once again, PySimpleGUI makes accessing these capabilities trivial. Creating a transparent window requires adding a single parameter to the call that creates your Window. One parameter change can result in a simple application with this effect:

You can interact with everything on your desktop, clicking through a full-screen window.


Themes

Tired of the default grey GUIs? PySimpleGUI makes it trivial for your window to look nice by making a single call to the theme function. There are over 150 different color themes available for you to choose:

img

With most GUI frameworks, you must specify the color for every widget you create. PySimpleGUI takes this chore from you and will automatically color the Elements to match your chosen theme.

To use a theme, call the theme function with the name of the theme before creating your window. You can add spaces for readability. To set the theme to "Dark Grey 9":

import PySimpleGUI as sg

sg.theme('dark grey 9')

This single line of code changes the window's appearance entirely:

img

The theme changed colors of the background, text, input background, input text, and button colors. In other GUI packages, to change color schemes like this, you would need to specify the colors of each widget individually, requiring numerous changes to your code.


Distribution

Want to share your PySimpleGUI program with friends and family that don't have Python installed on their computer? Try the GUI front-end for PyInstaller that you'll find in the psgcompiler project.


Support 💪

Your first stop should be the documentation and demo programs.

Be sure and install the Demo Browser (instructions in the Cookbook) so that you can search and run the 100s of demo programs.

If you still have a question or need help... no problem... help is available to you, at no cost. Simply file an Issue on the PySimpleGUI GitHub repo and you'll get help.

Nearly all software companies have a form that accompanies bug reports. It's not a bad trade... fill in the form, get free software support. This information helps get you an answer efficiently.

In addition to requesting information such as the version numbers of PySimpleGUI and underlying GUI frameworks, you're also given a checklist of items that may help you solve your problem.

Please fill in the form. It may feel pointless to you. It may feel painful, despite it taking just a moment. It helps get you a solution faster. If it wasn't useful and necessary information to help you get a speedy reply and fix, you wouldn't be asked to fill it out. "Help me help you".

Supporting img

Financial support for the project is greatly appreciated. To be honest, financial help is needed. It's expensive just keeping the lights on. The domain name registrations, a long list of subscriptions for things like Trinket, consulting help, etc., quickly add up to a sizable recurring cost.

PySimpleGUI wasn't inexpensive to create. While a labor of love, it was very laborious over several years, and quite a bit was invested, and continues to be invested, in creating what you see today.

PySimpleGUI has an open-source license and it would be great if it could remain that way. If you or your company (especially if you're using PySimpleGUI in a company) are benefiting financially by using PySimpleGUI, you have the capability of extending the life of the project for you and other users.

Buy Me A Coffee

Buy Me a Coffee is a great way to publicly support developers. It's quick, easy, and your contribution is recorded so that others can see that you're a supporter of PySimpleGUI. You can also choose to make your donation private.

Buy Me A Coffee

GitHub Sponsoring

The GitHub recurring sponsorship is how you can sponsor the project at varying levels of support on an ongoing basis. It's how many Open Source developers are able to receive corporate level sponsorship.

Your help in financially contributing to the project would be greatly appreciated. Being an Open Source developer is financially challenging. YouTube video creators are able to make a living creating videos. It's not so easy yet for Open Source developers.

Thank you for the Thank You's

To everyone that's helped, in whatever fashion, I'm very very grateful.

Even taking a moment to say "thank you" helps, and a HUGE number of you have done that. It's been an amazing number actually. I value these thanks and find inspiration in the words alone. Every message is a little push forward. It adds a little bit of energy and keeps the whole project's momentum. I'm so very grateful to everyone that's helped in whatever form it's been.

Contributing 👷

While PySimpleGUI is currently licensed under an open-source license, the project itself is structured like a proprietary product. Pull Requests are not accepted.

One of the best ways for you to contribute code is to write and publish applications. Users are inspired by seeing what other users build. Here's a simple set of steps you can take - Create a GitHub repo, post the code, and include a screenshot in your repo's readme file. Then come back to the PySimpleGUI repo and post a screenshot in Issue #10 or in the project's WIKI.

If there is a feature missing that you need or you have an enhancement to suggest, then open an Issue

Special Thanks 🙏

The PySimpleGUI team is tiny and they're all superstars. Every week I've been stunned by what they do. Dream-team is an understatement. Simply put @Chr0nicT, @jason990420, @Snaiel and Mike@PySimpleGUI are PySimpleGUI.

This version of the PySimpleGUI readme wouldn't have come together without the help from @M4cs. He's a fantastic developer and has been a PySimpleGUI supporter since the project's launch. @israel-dryer is another long-term supporter and has written several PySimpleGUI programs that pushed the envelope of the package's capabilities. The unique minesweeper that uses an image for the board was created by Israel. @jason990420 surprised many when he published the first card game using PySimpleGUI that you see pictured above as well as the first minesweeper game made with PySimpleGUI. @Chr0nicT is the youngest developer I've worked with, ever, on projects. This kid shocks me on a regular basis. Ask for a capability, such as the PySimpleGUI GitHub Issues form error checking bot, and it simply happens regardless of the technologies involved. I'm fortunate that we were introduced. Someday he's going to be whisked away, but until then we're all benefiting from his talent. @Snaiel made the Udemy course happen. It wouldn't have been 1/4th of what it is without his amazing skills in video production, course design, marketing brilliance, and web programming. The Japanese version of the readme was greatly improved with help from @okajun35. @nngogol has had a very large impact on the project, also getting involved with PySimpleGUI in the first year of initial release. He wrote a designer, came up with the familiar window[key] lookup syntax, wrote the tools that create the documentation, designed the first set of doc strings as well as tools that generate the online documenation using the PySimpleGUI code itself. PySimpleGUI would not be where it is today were it not for the help of these individuals.

The more than 4,000 GitHub repos that use PySimpleGUI are owed a "Thank You" as well, for it is you that has been the inspiration that fuels this project's engine.

The overseas users that post on Twitter overnight are the spark that starts the day's work on PySimpleGUI. They've been a source of positive energy that gets the development engine started and ready to run every day. As a token of appreciation, this readme file has been translated into Japanese.

PySimpleGUI users have been the best user community an Open Source developer could hope for. I've never seen expressions of gratitude and joy like PySimpleGUI users show on a daily basis.

© Copyright 2021, 2022 PySimpleGUI

Pinned

  1. PySimpleGUI-Photo-Colorizer PySimpleGUI-Photo-Colorizer Public

    Transform black and white images (or your webcam) into beautifully colored images using Deep Learning. Uses OpenCV and Numpy to Colorize your photo or webcam video. GUI provided by PySimpleGUI.

    Python 153 34

  2. rawpython/remi rawpython/remi Public

    Python REMote Interface library. Platform independent. In about 100 Kbytes, perfect for your diet.

    Python 3.4k 407

  3. PySimpleGUI PySimpleGUI Public

    Launched in 2018. It's 2023 and PySimpleGUI is actively developed & supported. Create complex windows simply. Supports tkinter, Qt, WxPython, Remi (in browser). Create GUI applications trivially wi…

    Python 12.8k 1.8k

  4. psgcompiler psgcompiler Public

    Transform your Python programs in Windows, Mac, and Linux binary executables (initially using pyinstaller... more being added)

    Python 128 15

  5. psgtray psgtray Public

    System Tray Icon for PySimpleGUI (the tkinter version). Adds a system tray icon by using pystray and PIL

    Python 49 8

  6. psgresizer psgresizer Public

    psgresizer - a PySimpleGUI application that will convert between formats, resize, and BASE64 encode your images. pip install psgresizer. Then type: psgresizer on the command line. An official PySim…

    Python 12 1

1,720 contributions in the last year

5 contributions on December 11th.4 contributions on December 18th.6 contributions on December 25th.2 contributions on January 1st.4 contributions on January 8th.13 contributions on January 15th.7 contributions on January 22nd.2 contributions on January 29th.4 contributions on February 5th.7 contributions on February 12th.6 contributions on February 19th.2 contributions on February 26th.10 contributions on March 5th.6 contributions on March 12th.3 contributions on March 19th.No contributions on March 26th.3 contributions on April 2nd.2 contributions on April 9th.12 contributions on April 16th.8 contributions on April 23rd.10 contributions on April 30th.8 contributions on May 7th.9 contributions on May 14th.4 contributions on May 21st.2 contributions on May 28th.No contributions on June 4th.1 contribution on June 11th.No contributions on June 18th.3 contributions on June 25th.1 contribution on July 2nd.1 contribution on July 9th.4 contributions on July 16th.1 contribution on July 23rd.2 contributions on July 30th.No contributions on August 6th.5 contributions on August 13th.3 contributions on August 20th.14 contributions on August 27th.11 contributions on September 3rd.1 contribution on September 10th.3 contributions on September 17th.2 contributions on September 24th.6 contributions on October 1st.17 contributions on October 8th.No contributions on October 15th.3 contributions on October 22nd.11 contributions on October 29th.1 contribution on November 5th.6 contributions on November 12th.2 contributions on November 19th.4 contributions on November 26th.8 contributions on December 3rd.8 contributions on December 10th.9 contributions on December 12th.7 contributions on December 19th.No contributions on December 26th.3 contributions on January 2nd.3 contributions on January 9th.No contributions on January 16th.No contributions on January 23rd.2 contributions on January 30th.3 contributions on February 6th.4 contributions on February 13th.No contributions on February 20th.3 contributions on February 27th.15 contributions on March 6th.14 contributions on March 13th.No contributions on March 20th.1 contribution on March 27th.4 contributions on April 3rd.No contributions on April 10th.8 contributions on April 17th.6 contributions on April 24th.6 contributions on May 1st.6 contributions on May 8th.3 contributions on May 15th.1 contribution on May 22nd.10 contributions on May 29th.No contributions on June 5th.No contributions on June 12th.5 contributions on June 19th.No contributions on June 26th.6 contributions on July 3rd.2 contributions on July 10th.6 contributions on July 17th.1 contribution on July 24th.12 contributions on July 31st.No contributions on August 7th.11 contributions on August 14th.15 contributions on August 21st.14 contributions on August 28th.1 contribution on September 4th.7 contributions on September 11th.13 contributions on September 18th.2 contributions on September 25th.20 contributions on October 2nd.1 contribution on October 9th.6 contributions on October 16th.2 contributions on October 23rd.8 contributions on October 30th.7 contributions on November 6th.5 contributions on November 13th.No contributions on November 20th.6 contributions on November 27th.5 contributions on December 4th.2 contributions on December 11th.4 contributions on December 13th.5 contributions on December 20th.3 contributions on December 27th.5 contributions on January 3rd.1 contribution on January 10th.No contributions on January 17th.No contributions on January 24th.2 contributions on January 31st.16 contributions on February 7th.1 contribution on February 14th.9 contributions on February 21st.5 contributions on February 28th.6 contributions on March 7th.2 contributions on March 14th.No contributions on March 21st.No contributions on March 28th.No contributions on April 4th.4 contributions on April 11th.21 contributions on April 18th.15 contributions on April 25th.4 contributions on May 2nd.9 contributions on May 9th.8 contributions on May 16th.No contributions on May 23rd.No contributions on May 30th.No contributions on June 6th.3 contributions on June 13th.4 contributions on June 20th.No contributions on June 27th.6 contributions on July 4th.1 contribution on July 11th.No contributions on July 18th.7 contributions on July 25th.6 contributions on August 1st.4 contributions on August 8th.2 contributions on August 15th.8 contributions on August 22nd.No contributions on August 29th.4 contributions on September 5th.11 contributions on September 12th.7 contributions on September 19th.11 contributions on September 26th.3 contributions on October 3rd.2 contributions on October 10th.5 contributions on October 17th.1 contribution on October 24th.No contributions on October 31st.5 contributions on November 7th.4 contributions on November 14th.No contributions on November 21st.No contributions on November 28th.9 contributions on December 5th.3 contributions on December 12th.3 contributions on December 14th.6 contributions on December 21st.7 contributions on December 28th.4 contributions on January 4th.No contributions on January 11th.3 contributions on January 18th.4 contributions on January 25th.No contributions on February 1st.4 contributions on February 8th.No contributions on February 15th.No contributions on February 22nd.4 contributions on March 1st.1 contribution on March 8th.16 contributions on March 15th.4 contributions on March 22nd.6 contributions on March 29th.4 contributions on April 5th.No contributions on April 12th.24 contributions on April 19th.11 contributions on April 26th.7 contributions on May 3rd.5 contributions on May 10th.10 contributions on May 17th.1 contribution on May 24th.1 contribution on May 31st.No contributions on June 7th.5 contributions on June 14th.3 contributions on June 21st.No contributions on June 28th.7 contributions on July 5th.6 contributions on July 12th.No contributions on July 19th.2 contributions on July 26th.3 contributions on August 2nd.5 contributions on August 9th.14 contributions on August 16th.4 contributions on August 23rd.1 contribution on August 30th.18 contributions on September 6th.1 contribution on September 13th.17 contributions on September 20th.11 contributions on September 27th.1 contribution on October 4th.No contributions on October 11th.1 contribution on October 18th.No contributions on October 25th.3 contributions on November 1st.1 contribution on November 8th.10 contributions on November 15th.No contributions on November 22nd.3 contributions on November 29th.5 contributions on December 6th.5 contributions on December 13th.4 contributions on December 15th.3 contributions on December 22nd.3 contributions on December 29th.4 contributions on January 5th.13 contributions on January 12th.2 contributions on January 19th.1 contribution on January 26th.2 contributions on February 2nd.No contributions on February 9th.3 contributions on February 16th.14 contributions on February 23rd.2 contributions on March 2nd.17 contributions on March 9th.2 contributions on March 16th.2 contributions on March 23rd.6 contributions on March 30th.3 contributions on April 6th.No contributions on April 13th.4 contributions on April 20th.3 contributions on April 27th.7 contributions on May 4th.6 contributions on May 11th.16 contributions on May 18th.2 contributions on May 25th.No contributions on June 1st.No contributions on June 8th.No contributions on June 15th.2 contributions on June 22nd.1 contribution on June 29th.No contributions on July 6th.No contributions on July 13th.1 contribution on July 20th.4 contributions on July 27th.14 contributions on August 3rd.5 contributions on August 10th.1 contribution on August 17th.6 contributions on August 24th.12 contributions on August 31st.9 contributions on September 7th.2 contributions on September 14th.9 contributions on September 21st.No contributions on September 28th.15 contributions on October 5th.No contributions on October 12th.3 contributions on October 19th.1 contribution on October 26th.5 contributions on November 2nd.4 contributions on November 9th.1 contribution on November 16th.3 contributions on November 23rd.6 contributions on November 30th.6 contributions on December 7th.9 contributions on December 14th.No contributions on December 16th.8 contributions on December 23rd.No contributions on December 30th.28 contributions on January 6th.7 contributions on January 13th.3 contributions on January 20th.No contributions on January 27th.No contributions on February 3rd.No contributions on February 10th.2 contributions on February 17th.18 contributions on February 24th.No contributions on March 3rd.No contributions on March 10th.1 contribution on March 17th.No contributions on March 24th.3 contributions on March 31st.12 contributions on April 7th.9 contributions on April 14th.29 contributions on April 21st.15 contributions on April 28th.7 contributions on May 5th.9 contributions on May 12th.2 contributions on May 19th.1 contribution on May 26th.No contributions on June 2nd.3 contributions on June 9th.No contributions on June 16th.6 contributions on June 23rd.5 contributions on June 30th.No contributions on July 7th.6 contributions on July 14th.No contributions on July 21st.No contributions on July 28th.4 contributions on August 4th.3 contributions on August 11th.8 contributions on August 18th.5 contributions on August 25th.5 contributions on September 1st.3 contributions on September 8th.2 contributions on September 15th.3 contributions on September 22nd.8 contributions on September 29th.3 contributions on October 6th.No contributions on October 13th.3 contributions on October 20th.18 contributions on October 27th.No contributions on November 3rd.5 contributions on November 10th.9 contributions on November 17th.3 contributions on November 24th.13 contributions on December 1st.9 contributions on December 8th.No contributions on December 15th.4 contributions on December 17th.No contributions on December 24th.No contributions on December 31st.No contributions on January 7th.3 contributions on January 14th.3 contributions on January 21st.1 contribution on January 28th.3 contributions on February 4th.10 contributions on February 11th.4 contributions on February 18th.5 contributions on February 25th.3 contributions on March 4th.No contributions on March 11th.No contributions on March 18th.1 contribution on March 25th.No contributions on April 1st.1 contribution on April 8th.6 contributions on April 15th.11 contributions on April 22nd.6 contributions on April 29th.8 contributions on May 6th.1 contribution on May 13th.11 contributions on May 20th.No contributions on May 27th.No contributions on June 3rd.1 contribution on June 10th.No contributions on June 17th.No contributions on June 24th.No contributions on July 1st.2 contributions on July 8th.No contributions on July 15th.6 contributions on July 22nd.12 contributions on July 29th.5 contributions on August 5th.6 contributions on August 12th.5 contributions on August 19th.4 contributions on August 26th.1 contribution on September 2nd.15 contributions on September 9th.3 contributions on September 16th.6 contributions on September 23rd.No contributions on September 30th.16 contributions on October 7th.No contributions on October 14th.4 contributions on October 21st.2 contributions on October 28th.5 contributions on November 4th.2 contributions on November 11th.4 contributions on November 18th.13 contributions on November 25th.5 contributions on December 2nd.7 contributions on December 9th.
Contribution Graph
Day of Week December January February March April May June July August September October November December
Sunday
Monday
Tuesday
Wednesday
Thursday
Friday
Saturday
Less
No contributions.
Low contributions.
Medium-low contributions.
Medium-high contributions.
High contributions.
More

Activity overview

Contributed to PySimpleGUI/PySimpleGUI, PySimpleGUI/psgtest, MaxSSD/OpenAI-GUI and 56 other repositories
A graph representing PySimpleGUI's contributions from December 11, 2022 to December 15, 2023. The contributions are 81% commits, 12% issues, 7% pull requests, 0% code review.

Contribution activity

December 2023

Opened 1 issue in 1 repository
h0m4m/RestaurantManager 1 open
93 contributions in private repositories Dec 1 – Dec 14

Seeing something unexpected? Take a look at the GitHub profile guide.