data:image/s3,"s3://crabby-images/940e0/940e00a18e6756bb41bce20fb81efcb1a8fa17e0" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
许多Python学习者在学习如何创建一个 GUI 应用的时候都感到十分的困难。其中最重要的原因是,他们不知道应该从何下手。大多数的教程都只有文字,但事实上仅仅依靠文字很难学会 GUI 编程,因为 GUI 应用大多数都是基于视觉上的。
data:image/s3,"s3://crabby-images/af4b7/af4b73cb3fd38e1a1be9dbdc8fa8aeedf7183d8c" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
这就是我们即将完成的东西:
data:image/s3,"s3://crabby-images/22bb1/22bb1a8754e163e8e643e347f3567923ba052375" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
这是一个简单的 GUI 应用,根据输入的价格(price)和税率(tax rate),计算出最终的价格(final price)。
data:image/s3,"s3://crabby-images/4782b/4782b915ee2b84a32cef2136e5f904a51027ea28" alt=""
image
大多数的教程都试图直接通过Python代码来对 GUI 应用进行布局,但是这样做实在是很费劲。我们将要做的是利用优秀的 QT Designer 工具来对我们的应用进行布局。
data:image/s3,"s3://crabby-images/5a4b6/5a4b6e1e821568346eb82ee402e73b59b9c6814c" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
不要再用代码来设计界面了。所有的东西都将通过图形界面来搞定。
前提
如果你已经接受了我的建议并且安装了 Anaconda,你应该已经安装好了 PyQt4。如果没有的话,你需要从这里先下载它。
data:image/s3,"s3://crabby-images/f4fc4/f4fc40ed510a7f0cf4b9b2f8972b269cc5728a2f" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
着手
打开 QT Designer。在弹出的窗口中,选择 Main Window,这样它会给你一个空白的画板。
data:image/s3,"s3://crabby-images/7cb39/7cb394593612d2c49ea8f9bcc4ad5d5b9a7eb69b" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
接下来在左侧选择Text Edit:
data:image/s3,"s3://crabby-images/804db/804db98238ec26817103d41e810c5e3177e73100" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
将Text Edit 拖动到主窗口:
data:image/s3,"s3://crabby-images/d381f/d381f016de7efa6727a4dcdfd8cd28b29d2c64f0" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
红圈框起来的部分就是定义这个对象的名字的地方。这个名字将是我们通过 Python 代码调用到这个对象的变量名。
data:image/s3,"s3://crabby-images/b9b48/b9b485010753b4f4c287f294def34417861b668f" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
我将它取名为price_box,因为我们会在这里输入价格。然后我们需要给这个输入框添加一个 label(按钮),以便让用户更加清楚这个输入框的作用。
data:image/s3,"s3://crabby-images/ab9a0/ab9a0fb30224e860dbf4cc77d8358e8ac5ae5105" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
我在上图中圈出了 label。把它拖动到主窗口当中来。
data:image/s3,"s3://crabby-images/89a5f/89a5fbc615e9387d8433946fa4f053f8bdb42659" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
data:image/s3,"s3://crabby-images/b46c8/b46c8fafe3b9b9a20d3342b0793f6dba7dcfbb17" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
data:image/s3,"s3://crabby-images/644c1/644c1d6ba28d8dc98a7bf7dd53da52b4173f173a" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
对于税率(tax)输入框,我们会使用另外的一个东西。找到spin box:
data:image/s3,"s3://crabby-images/2a928/2a9288c5d5cf5fb5e26e1c05b8c7ee07269aae89" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
左侧用圈框起来的部分就是一个spin box。
data:image/s3,"s3://crabby-images/3d0b3/3d0b396f693cad4074eff0bab38810584116bc53" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
请记住这将会是你在 Python 代码中调用它的时候会使用到的变量名。
data:image/s3,"s3://crabby-images/7d555/7d555fd550075ab476caa5e1aec82a46717b37c2" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
我们可以为我们的spin box 设置一个默认值。我选择将其设置为 20:
data:image/s3,"s3://crabby-images/9e3e1/9e3e199655299bac9473c1c47fbb0932dbdf7e78" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
你会发现我们也可以设置它的最小值和最大值。不过我并不打算去更改他们。
同样地,我会为它添加一个标签叫做Tax Rate。然后看看我们接下来会用到的圈起来的Push Button:
data:image/s3,"s3://crabby-images/12520/125203982520636e8f3312740fa01fdfe9a36395" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
好的,现在选择Push Button 然后将其拖动到我们的窗口中来。
data:image/s3,"s3://crabby-images/0bffa/0bffafce2eeb530e0800403f2fc92aa8309ab84a" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
这个按钮现在显示的是PushButton,这并不是一个很有意义的名字。
data:image/s3,"s3://crabby-images/3893b/3893bdc313c3d4ca7304211d1eb08bdf41255cb8" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
data:image/s3,"s3://crabby-images/2ade6/2ade67d09bb1c71711751a8bd45aac27643f39af" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
然后,我们可以修改真正的显示文字列了:
data:image/s3,"s3://crabby-images/9ba55/9ba55b8e3903e9a71c185d94b5aa59d91d075ed9" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
data:image/s3,"s3://crabby-images/126fc/126fc2d4f6d787cec5d9087bbcfc502450c8e307" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
data:image/s3,"s3://crabby-images/9133e/9133e2f7c56f78ee8f32583c003992e9aa4b1392" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
如果你觉得需要的话,你可以添加一个大标题。这是一个简单的label box 并且将字体加大了。
data:image/s3,"s3://crabby-images/1fc38/1fc38efa0136f192d43f7dab2cf79ae4c63b4e74" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
现在保存你的成果:
data:image/s3,"s3://crabby-images/7570e/7570e5845519e88b5c20682dc03fb372285682d9" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
data:image/s3,"s3://crabby-images/5699c/5699c61471a107b606ef6d214b7b8e001974dd53" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
data:image/s3,"s3://crabby-images/188ac/188acdd39667e9a3f1ead291d5b462aeb818c909" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
编写python代码
Qt 代码是面向对象的,并且简单易学。所有我们添加的组件都是一个对象,并且都拥有自己的方法比如toPlainText()(用来读取输入框中的值)。这让它使用起来非常方便。
这些代码非常有用,每当你想要创建一个新的 PyQt 项目的时候,就在这段代码的基础上添加你自己的代码吧。
这段代码如下:
data:image/s3,"s3://crabby-images/5b9a6/5b9a63b64b485b0ccad2fbc3423a444dd50ecf39" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
注意第三行:
data:image/s3,"s3://crabby-images/3e5c2/3e5c2b31dccf8969511295b6f7cc8439eafce1ba" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
你需要在这里填入你先前创建的文件的地址。这个文件将会被内置的函数载入:
data:image/s3,"s3://crabby-images/b508f/b508ffd120e9072fb4ccd3c4a22f18eae34937ee" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
让我们大致地看一看这段代码:
data:image/s3,"s3://crabby-images/51794/51794a99bb44b71a68d2a065cad3961a746a018e" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
data:image/s3,"s3://crabby-images/6c2f7/6c2f767865982fcd52fac27c37d6f913c12e3566" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
data:image/s3,"s3://crabby-images/83759/83759c39111cec1f6bb5a8abec466b1e6e02070f" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
你不一定非得要了解这些代码的细节。你只需要在它的基础上继续开发就好了。
下载pyqt_skeleton.py 这个文件,并将它重命名为pyqt_first.py。这是因为我们不想去改动到源文件。然后要做的第一件事就是在代码中导入我们自己的 XML 文件,这个 XML 文件包含了我们的这个 GUI 信息。将下面的这一行:
data:image/s3,"s3://crabby-images/48850/4885072f1242c5a8388a88fac0b2b356a0b53008" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
替换为
data:image/s3,"s3://crabby-images/74e81/74e816580fc56b9fcf8085b8054c22a267ec25dc" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
data:image/s3,"s3://crabby-images/dfd85/dfd851a00d2d29185bcbe297e3f14918e51d2dbe" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
data:image/s3,"s3://crabby-images/09487/09487041ca074bce99c4bf624220e2660218ea4e" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
data:image/s3,"s3://crabby-images/efa9a/efa9a7008b37b7580bd54a92de12838e68b2a48b" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
我们还没有实现这个函数。所以让我们动手开始写吧。
在MyApp 类中,添加另外一个函数。我们需要先看看整个函数,然后再去了解它的细节:
data:image/s3,"s3://crabby-images/f6d93/f6d93ac8c43988c4861c7f1f5c55bdd4be9e1e0d" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
好了,让我们一行一行的分析上面的代码。
我们现在要做两件事:读取价格和税率,然后计算最终的价格。好了开始吧。请记住,我们要通过我们设定的名字来调用这些组件(这就是我让你不要用默认的通用名称比如box1 的原因,否则的话我们在写代码的时候会很恼火)。
data:image/s3,"s3://crabby-images/a7751/a7751022e9d1e89f580abedb128e9365d8495a55" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
data:image/s3,"s3://crabby-images/b9115/b911528f3eace9872869dac776b3f3d6e0a24ca7" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
Python
data:image/s3,"s3://crabby-images/b2ce8/b2ce8f52cf91e4f79e40310bc8f74f59d23f20fb" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
data:image/s3,"s3://crabby-images/3e631/3e631e86ab7ae38809010ee21f2204c2c14f9d6e" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
最后运行我们写好的程序:
Python
python pyqt_first.py
data:image/s3,"s3://crabby-images/ab391/ab39182532a5a7cfaf75abd8efca44e2d5253d9c" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
data:image/s3,"s3://crabby-images/d2cde/d2cdee7a99ffa22488ee659cd84c3e5cf5e2cf46" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
好了,这就是一个简单的 PyQt 教程。
如果你还想要体验更多好玩儿的东西,你可以试着用一用别的组件。
data:image/s3,"s3://crabby-images/9ab02/9ab0226ddbc97dcb6053675cfbaea2ae0417e039" alt=""
PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!
网友评论