目录
随着Python在数据科学、机器学习和Web开发等多个领域的广泛应用,图形用户界面(GUI)开发也变得越来越重要。对于初学者和快速原型设计来说,使用复杂的GUI库可能会让人感到望而生畏。幸运的是,Python的EasyGUI库提供了一个简单而直观的方式来创建基本的图形用户界面,无需深入了解复杂的GUI编程概念。
EasyGUI是一个用于非常简单的Python GUI编程的库。与Tkinter等更高级的库相比,EasyGUI通过提供一系列预构建的对话框和简单的函数调用来简化GUI开发过程。这使得开发者可以专注于应用程序的逻辑,而不是花费大量时间在界面设计上。
fileopenbox(msg=None, title=None, default='*', filetypes=None, multiple=False)
? ? Displays an "open file" dialog box and returns the selected file as a string.
? ? The "default" argument specifies a filepath that (normally)?contains one or more wildcards.
? ? fileopenbox() will display only files that match the default filepath.
? ? If omitted, defaults to "\*" (all files in the current directory).
? ? :param str msg: the msg to be displayed.
? ? :param str title: the window title
? ? :param str default: filepath with wildcards
? ? :param object filetypes: filemasks that a user can choose, e.g. "\*.txt"
? ? :param bool multiple: If true, more than one file can be selected
? ? :return: the name of a file, or None if user chose to cancel
显示“打开文件”对话框,并将所选文件作为字符串返回。“default”参数指定(通常)包含一个或多个通配符的文件路径。例如,默认打开Excel文件如下:
import easygui as eg
eg.fileopenbox(msg=None, title=None, default='*.xls', filetypes=None, multiple=False)
filesavebox(msg=None, title=None, default='', filetypes=None)
? ? A file to get the name of a file to save.
? ? Returns the name of a file, or None if user chose to cancel.
? ? **About the "default" argument**
? ? The ``default`` argument specifies the path and "glob pattern" for file names. The "\*" value, for example, sets the open file dialog to the current working directory and showing all files.
? ? For another example, setting the ``default`` argument to ``"C:/myjunk/*.py"`` sets the open file dialog to the C:\myjunk folder and showing only files that have the .py file extension. This glob pattern at the end of the ``default`` argument is required: passing ``"C:/myjunk"`` would not set the open file dialog to the C:\myjunk folder, but rather to the C:\ folder and "myjunk" as the initial filename.
? ? Note that on Windows, ``fileopenbox()`` automatically changes the path separator to the Windows path separator (backslash).
? ? The "filetypes" argument works like the "filetypes" argument to fileopenbox.
? ? :param str msg: the msg to be displayed.
? ? :param str title: the window title
? ? :param str default: default filename to return
? ? :param object filetypes: filemasks that a user can choose, e.g. " \*.txt"
? ? :return: the name of a file, or None if user chose to cancel
用于获取要保存的文件的名称的文件。返回文件名,如果用户选择取消,则返回“无”。
import easygui as eg
eg.filesavebox(msg=None, title=None, default='*.xls', filetypes=None)
diropenbox(msg=None, title=None, default=None)
? ? A dialog to get a directory name.
? ? Returns the name of a directory, or None if user chose to cancel.
? ? If the "default" argument specifies a directory name, and that?directory exists, then the dialog box will start with that directory.
? ? :param str msg: used in the window title on some platforms
? ? :param str title: the window title
? ? :param str default: starting directory when dialog opens
? ? :return: Normalized path selected by user
用于获取目录名的对话框。返回目录的名称,如果用户选择取消,则返回“无”。
如果“default”参数指定了一个目录名,并且该目录存在,则对话框将从该目录开始。
import easygui as eg
eg.diropenbox(msg=None, title=None, default=r'E:\Tables')
indexbox(msg='Shall I continue?', title=' ', choices=('Yes', 'No'), image=None, default_choice='Yes', cancel_choice='No')
? ? The ``indexbox()`` function displays a set of buttons, and returns the index of the selected button. For example, if you invoked index box with three choices (A, B, C), indexbox would return 0 if the user picked A, 1 if he picked B, and 2 if he picked C.
? ? :param str msg: the msg to be displayed
? ? :param str title: the window title
? ? :param list choices: a list or tuple of the choices to be displayed
? ? :param str image: Filename of image to display
? ? :param str default_choice: The choice you want highlighted when the gui appears
? ? :param str cancel_choice: If the user presses the 'X' close,?which button should be pressed
? ? :return: the index of the choice selected, starting from 0
显示一组按钮,并返回所选按钮的索引。例如,如果您使用三个选项(A、B、C)调用索引框,则如果用户选择A,indexbox将返回0,如果用户选择B,则返回1,如果选择C,则返回2。
import easygui as eg
result = eg.indexbox('Which door do you choose?', 'Win Prizes!', choices=['Door 1', 'Door 2', 'Door 3'])
if result == 2:
eg.msgbox('You win a new car!')
else:
eg.msgbox('Better luck next time.')
exceptionbox(msg=None, title=None)
? ? Display a box that gives information about an exception that has just been raised.
? ? The caller may optionally pass in a title for the window, or a msg to accompany the error information.
? ? Note that you do not need to (and cannot) pass an exception object as an argument. ?The latest exception will automatically be used.
? ? :param str msg: the msg to be displayed
? ? :param str title: the window title
? ? :return: None
报告错误或例外异常的信息,调用者可以选择性地传入窗口的标题或伴随错误信息的消息。
codebox(msg='', title=' ', text='')
? ? Display some text in a monospaced font, with no line wrapping.
? ? This function is suitable for displaying code and text that is formatted using spaces.
? ? The text parameter should be a string, or a list or tuple of lines to be displayed in the textbox.
? ? :param str msg: the msg to be displayed
? ? :param str title: the window title
? ? :param str text: what to display in the textbox
与多行文本框textbox(msg='', title=' ', text='', codebox=False, callback=None, run=True)很相似,少了后面三个参数:
passwordbox(msg='Enter your password.', title=' ', default='', image=None, root=None)
? ? Show a box in which a user can enter a password.
? ? The text is masked with asterisks, so the password is not displayed.
? ? :param str msg: the msg to be displayed.
? ? :param str title: the window title
? ? :param str default: value returned if user does not change it
? ? :return: the text that the user entered, or None if they cancel
? ? ? the operation.
显示一个框,用户可以在其中输入密码。文本用星号屏蔽,因此不会显示密码。
import easygui as eg
eg.passwordbox(msg='请输入密码:', title='密码输入框', default='456123', image=None, root=None)
multenterbox(msg='Fill in values for the fields.', title=' ', fields=[], values=[], callback=None, run=True)
? ? Show screen with multiple data entry fields.
? ? If there are fewer values than names, the list of values is padded with empty strings until the number of values is the same as the number of names.
? ? If there are more values than names, the list of values is truncated so that there are as many values as names.
? ? Returns a list of the values of the fields,?or None if the user cancels the operation.
? ? :param str msg: the msg to be displayed.
? ? :param str title: the window title
? ? :param list fields: a list of fieldnames.
? ? :param list values: a list of field values
? ? :return: String
显示包含多个数据输入字段,即同一个对话框中有多个单行文本框。例如:
import easygui as eg
msg = "Enter your personal information"
title = "Credit Card Application"
fieldNames = ["Name","Address","City","State","ZipCode"]
fieldValues = [] # we start with blanks for the values
fieldValues = eg.multenterbox(msg,title, fieldNames)
# make sure that none of the fields was left blank
while 1:
if fieldValues is None: break
errmsg = ""
for i in range(len(fieldNames)):
if fieldValues[i].strip() == "":
errmsg += ('"%s" is a required field.\n\n' % fieldNames[i])
if errmsg == "":
break # no problems found
fieldValues = eg.multenterbox(errmsg, title, fieldNames, fieldValues)
print("Reply was: %s" % str(fieldValues))
multpasswordbox(msg='Fill in values for the fields.', title=' ', fields=(), values=(), callback=None, run=True)
? ? Same interface as multenterbox. ?But in multpassword box,?the last of the fields is assumed to be a password, and?is masked with asterisks.
? ? :param str msg: the msg to be displayed.
? ? :param str title: the window title
? ? :param list fields: a list of fieldnames.
? ? :param list values: a list of field values
? ? :return: String
与多重文本框相似,但最后一个是密码框,输入会补星号代替,例如:
import easygui as eg
msg = "输入你的登录信息:"
title = "组合密码框"
fieldNames = ["账号:", "密码:"]
fieldValues = eg.multpasswordbox(msg,title, fieldNames)
# make sure that none of the fields was left blank
while 1:
if fieldValues[0].strip() == "":
errmsg = '账号不可为空!'
fieldValues = eg.multpasswordbox(errmsg, title, fieldNames, fieldValues)
elif fieldValues[1].strip() == "":
errmsg = '密码不可为空!'
fieldValues = eg.multpasswordbox(errmsg, title, fieldNames, fieldValues)
else:
break
print("账号、密码分别为: %s" % fieldValues)
multchoicebox(msg='Pick an item', title='', choices=None, preselect=0, callback=None, run=True)
? ? The ``multchoicebox()`` function provides a way for a user to select from a list of choices. The interface looks just like the ``choicebox()`` function's dialog box, but the user may select zero, one, or multiple choices.
? ? The choices are specified in a sequence (a tuple or a list).
? ? :param str msg: the msg to be displayed
? ? :param str title: the window title
? ? :param list choices: a list or tuple of the choices to be displayed
? ? :param preselect: Which item, if any are preselected when dialog appears
? ? :return: A list of strings of the selected choices or None if cancelled.
与单项选择框 choicebox() 相似,只有单项选择和多项选择的区别:
import easygui as eg
msg ="What is your favorite flavor?"
title = "Ice Cream Survey"
choices = ["Vanilla", "Chocolate", "Strawberry", "Rocky Road"]
choice = eg.multchoicebox(msg, title, choices)
EasyGUI为Python开发者提供了一个快速创建基本图形用户界面的途径。它降低了GUI开发的门槛,使得即使是没有经验的开发者也能轻松构建出功能完善的界面。尽管它可能不适合复杂的应用程序或专业的软件开发项目,但对于快速原型设计、小型项目和教学目的来说,它是一个强大而高效的工具。通过利用EasyGUI的简单性和灵活性,开发者可以专注于解决问题,而不是纠结于复杂的界面细节。
完