Cookbook ======== .. toctree:: :maxdepth: 4 A section to hold code snippets and recipes ------------------------------------------- #. Simple demo program Here is a simple demo program using easygui. The screens that it produces are shown on the easygui home page. .. doctest:: from easygui import * import sys while 1: msgbox("Hello, world!") msg ="What is your favorite flavor?" title = "Ice Cream Survey" choices = ["Vanilla", "Chocolate", "Strawberry", "Rocky Road"] choice = choicebox(msg, title, choices) # note that we convert choice to string, in case # the user cancelled the choice, and we got None. msgbox("You chose: " + str(choice), "Survey Result") msg = "Do you want to continue?" title = "Please Confirm" if ccbox(msg, title): # show a Continue/Cancel dialog pass # user chose Continue else: sys.exit(0) # user chose Cancel #. Controlling the order of items in choicebox In a choicebox, the choices must be in sort order so that the keyboard "jump to" feature (jump down in the list by pressing keyboard keys) will work. But it often happens that a sort of first-cut listing of choices doesn't sort in a user-friendly order. So what can you do to control the order of the items displayed in a choicebox? A useful technique is to specify keys for the items in the choicebox. For example, suppose you want a choicebox to display View, Update, Delete, Exit. If you specified your choices this way:: choices = ["View", "Update", "Delete", "Exit"] you'd get this: - Delete - Exit - Update - View It is definitely in alphabetic order, but not very user-friendly. But if you specified keys for your choices this way:: choices = ["V View", "U Update", "D elete", "X Exit"] you'd get this (with "X" appearing at the bottom): - D Delete - U Update - V View - X Exit Suppose you wanted to force View to the top, so it is the easiest choice to select. You could change its key from "V" to "A":: choices = ["A View", "U Update", "D elete", "X Exit"] and you'd get this: - A View - D Delete - U Update - X Exit Another technique is to prepend a space to the choice. Since space characters always sorts before a non-space character, you can use this trick to force something like "V View" to the top of the list:: choices = [" V View", "U Update", "D Delete", "X Exit"] produces this: - V View - D Delete - U Update - X Exit In the proportional font used by choicebox, the space before the "V" is almost imperceptible. Personally, I prefer to use alphabetic keys rather than numeric keys for choicebox items. It is easier to navigate the choices using alpha keys on the keyboard than by using the number keys. And it is possible to use multi-character keys, like this: - L1 Log old version - L2 Log new version Using keys for choices also makes it relatively easy to check for the user's selection:: choices = [" V View", "U Update", "D elete", "X Exit"] choice = choicebox(msg,title,choices) if choice == None: return reply = choice.split()[0] # reply = the first word of the choice if reply == "X": return elif reply == "V": processView() elif reply == "L1": saveLog(version="old") elif reply == "L2": saveLog(version="new") #. Registration System demo The Registration System demo application is a simple database application to maintain a list of courses, and students who are registered for the courses. It is not completely implemented -- its purpose is to give you a feel for what is possible with EasyGui and how you might do it, not to be a complete working application. File: :download:`registration zip file <_static/registration_system/easygui_demo_registration_app.zip>` Screenshots: .. image:: _static/registration_system/screenshot_register_main.png :align: center .. image:: _static/registration_system/screenshot_register_show.png :align: center