Python Programming/GUI Programming< Python Programming
There are various GUI toolkits usable from Python.
Very productive are true GUI-builders, where the programmer can arrange the GUI window and other components such as database by using the mouse only in an intuitive fashion like in Windows Delphi 2.0. Very little typing is required. For python, only Boa Constructor follows this paradigm. WXglade and Qt-designer, monkey studio etc. come somewhat near but remain incomplete.
Disadvantages with the following kits described below are:
- Difficult deployment - the apps won't run on a particular GNU-Linux installation without major additional work
- breakage - apps won't work due to bit-rot.
Tkinter is a Python wrapper for Tcl/Tk providing a cross-platform GUI toolkit. On Windows, it comes bundled with Python; on other operating systems, it can be installed. The set of available widgets is smaller than in some other toolkits, but since Tkinter widgets are extensible, many of the missing compound widgets can be created using the extensibility, such as combo box and scrolling pane.
A minimal example:
from Tkinter import * root = Tk() frame = Frame(root) frame.pack() label = Label(frame, text="Hey there.") label.pack() quitButton = Button(frame, text="Quit", command=frame.quit) quitButton.pack() root.mainloop()
Main chapter: Tkinter.
See also book PyGTK For GUI Programming
PyGTK provides a convenient wrapper for the GTK+ library for use in Python programs, taking care of many of the boring details such as managing memory and type casting. The bare GTK+ toolkit runs on Linux, Windows, and Mac OS X (port in progress), but the more extensive features — when combined with PyORBit and gnome-python — require a GNOME install, and can be used to write full featured GNOME applications.
from PyQt4.QtCore import * from PyQt4.QtGui import * class App(QApplication): def __init__(self, argv): super(App, self).__init__(argv) self.msg = QLabel("Hello, World!") self.msg.show() if __name__ == "__main__": import sys app = App(sys.argv) sys.exit(app.exec_())
Bindings for the cross platform toolkit wxWidgets. WxWidgets is available on Windows, Macintosh, and Unix/Linux.
import wx class test(wx.App): def __init__(self): wx.App.__init__(self, redirect=False) def OnInit(self): frame = wx.Frame(None, -1, "Test", pos=(50,50), size=(100,40), style=wx.DEFAULT_FRAME_STYLE) button = wx.Button(frame, -1, "Hello World!", (20, 20)) self.frame = frame self.frame.Show() return True if __name__ == '__main__': app = test() app.MainLoop()
Dabo is a full 3-tier application framework. Its UI layer wraps wxPython, and greatly simplifies the syntax.
import dabo dabo.ui.loadUI("wx") class TestForm(dabo.ui.dForm): def afterInit(self): self.Caption = "Test" self.Position = (50, 50) self.Size = (100, 40) self.btn = dabo.ui.dButton(self, Caption="Hello World", OnHit=self.onButtonClick) self.Sizer.append(self.btn, halign="center", border=20) def onButtonClick(self, evt): dabo.ui.info("Hello World!") if __name__ == '__main__': app = dabo.ui.dApp() app.MainFormClass = TestForm app.start()
The "Hello World" example in pyFltk looks like:
from fltk import * window = Fl_Window(100, 100, 200, 90) button = Fl_Button(9,20,180,50) button.label("Hello World") window.end() window.show() Fl.run()
- PyKDE - Part of the kdebindings package, it provides a python wrapper for the KDE libraries.
- PyXPCOM provides a wrapper around the Mozilla XPCOM component architecture, thereby enabling the use of standalone XUL applications in Python. The XUL toolkit has traditionally been wrapped up in various other parts of XPCOM, but with the advent of libxul and XULRunner this should become more feasible. These days, nobody uses PyXPCOM for very good reasons: PyXPCOM gives one dead links and outdated incompatible firefox extensions.
- Graphic User Interface FAQ, python.org
- An excerpt from Chapter 20: GUI Development, from Python Programming on Win32, onlamp.com, by Mark Hammond, Andy Robinson; covers Tkinter, PythonWin and wxPython
- Google Ngram Viewer: Tkinter, wxPython, wxWidgets, PyGTK, PyQt