Gooey—— 把 CLI 程序变成 GUI | Python One to Million

Gooey 是一个 Python GUI 程序开发框架,基于 wxPython GUI 库,其使用方法类似于 Python 内置 CLI 开发库 argparse,因此很容易把一个基于 argparse 的 CLI 应用转换成 GUI 程序。

# 简单的示例

我们首先从一个简单的基于 argparse 库的 CLI 应用开始:

1
2
3
4
5
6
7
8
9
10
from argparse import ArgumentParser

def main():
parser = ArgumentParser(description="My Cool GUI Program!")
parser.add_argument('Filename')
parser.add_argument('Date')
parser.parse_args()

if __name__ == '__main__':
main()

这就有了一个接受 FilenameDate 的两个必填参数的 CLI 程序,为了简化程序我们并没有指定它的功能。

使用方法: python cli.py FILENAME DATE

现在我们把它改成

1
2
3
4
5
6
7
8
9
10
11
from gooey import Gooey, GooeyParser

@Gooey
def main():
parser = GooeyParser(description="My Cool GUI Program!")
parser.add_argument('Filename')
parser.add_argument('Date')
parser.parse_args()

if __name__ == '__main__':
main()

于是我们得到了一个简单的 GUI 对话框,并且基本上没有修过多少代码:

当然,仅仅这样是不够的,我们的 Filename 参数需要对应一个文件,而 Date 参数是一个日期,如果有专用的控件就好了! Gooey 当然也想到了:

仅仅修改了 2 行代码:

1
2
parser.add_argument('Filename', widget="FileChooser")
parser.add_argument('Date', widget="DateChooser")

# 控件

上面已经看到了两个简单的控件: FileChooserDateChooser ,分别提供了一个 “文件选择器” 和 “日期选择器”。现在支持的 chooser 类控件有:

控件名 控件类型
FileChooser 文件选择器
MultiFileChooser 文件多选器
DirChooser 目录选择器
MultiDirChooser 目录多选器
FileSaver 文件保存
DateChooser 日期选择
TextField 文本输入框
Dropdown 下拉列表
Counter 计数器
CheckBox 复选框
RadioGroup 单选框

# 国际化

Gooey 的国际化是通过配置实现的,使用方法如下:

1
2
3
@Gooey(language='russian')
def main():
...

目前仅支持 russianenglishdutchfrenchportuguese 的支持已在计划中。

# 配置

language 参数配置一样,Gooey 还支持很多其它配置,下面是它支持的参数列表:

参数 简介
advanced 切换显示全部设置还是仅仅是简化版本
show_config Skips the configuration all together and runs the program immediately
language 指定从 gooey/languages 目录读取哪个语言包
program_name GUI 窗口显示的程序名。默认会显 sys.argv[0]
program_description Settings 窗口顶栏显示的描述性文字。默认值从 ArgumentParser 中获取。
default_size 窗口默认大小。
required_cols 设置必选参数行数。
optional_cols 设置可选参数行数。
dump_build_config 将设置以 JSON 格式保存在硬盘中以供编辑 / 重用。

# 布局流

布局实例可以在下载这个 exmaple 库 体验。

Flat Layout Column Layout
Edited on