PyQt5开发实践(一、准备篇)
前言
近一年来我开发了不少PyQt小项目,因为之前没用过使用C++语言的Qt,所以可以算是从零基础开始边学边做的,这个过程中再一次体会到国内技术社区的匮乏…… 国内关于PyQt的资料说少不少,说多也不多,主要是比较零散,也没什么比较好用的系统的学习资料… 所以这个PyQt,全靠看文档和国外社区,还有一个最重要的:自己摸索……
开发环境搭建
本文的开发环境搭建一部分是从书里学来的,一部分是实践中总结的,总之在目前没有一种比较好用的PyQt集成开发工具的情况下,达到暂时的比较高效的开发模式。
目前我用的PyQt开发方式沿用传统的MVC架构,将界面布局和逻辑实现分开~
具体:
- 用QtDesigner设计好界面,保存为
*.ui文件,然后使用PyQt工具中的pyuic5将ui文件转换为py文件,这个就是view - 在controller包新建对应的py文件,用来实现界面中的相应逻辑
项目结构参考:

使用QtDesigner
这个QtDesigner很简陋,别说跟VS比,就是跟Android Studio或者是IDEA里的Swing界面设计工具比起来,都算是弟弟,大概相当于98年的VB6.0六七成水平吧……
不过也聊胜于无,至少能设计简单的界面,就可以了。
由于Flutter、Android App写多了,我很习惯用各种线性布局,Qt在布局方面也不赖,有Hlayout和Vlayout可以用,在QtDesigner里使用也很方便:创建一个Main window,然后放几个控件上去,右键设置布局就好了,然后就可以尽情使用HLayout或者VLayout、GridLayout各类组件来做布局,如图:

安装PyQt工具
为了能使用前文提到的诸如QtDesigner、pyuic5工具,需要先安装。
pip install pyqt5
pip install pyqt5-tools
安装完之后就可以在Python安装目录下的Lib/site-packages下找到PyQt5和pyqt5-tools文件夹,我们要的QtDesigner、pyuic5等工具就在pyqt5-tools文件夹下。
在PyCharm中配置外部工具
为了让PyCharm可以更方便的做PyQt开发,还得配置几个外部工具,配置完之后进行一些快捷操作:比如右键ui文件可以直接使用QtDesigner打开,也可以使用将UI文件转换为py文件,如图:

具体配置方法如下:
首先,File->Settings,打开PyCharm的设置,选择到External Tools界面,如图

这里选择加号按钮打开添加页面,我们先把QtDesigner添加进去,如图

接着添加pyuic5工具,这个工具的命令参数格式是这样的:
{pyuic5_path} -o {target_path} {file_path}
所以配置方法是这样:

参数部分我再复制一下:
-o $FileDir$/$FileNameWithoutExtension$.py $FilePath$
推荐一个小开源项目
这是我之前写的一个简单的视频合并工具,下面是简单项目介绍
想合并视频,但是却找不到比较好用的工具,很多都要收费,我想着「这破功能还得收费?」,于是决定自己搞一个,一开始用Python做了一个,效果还不错,完美完成了我的视频合并任务,不过没有图形界面,想分享给朋友一起用也没办法,于是用Qt写了个图形界面套上去就有了本项目

地址:https://github.com/Deali-Axy/VideoMerge
推荐一本书
虽说国内系统的学习资料很少,不过也是让我找到了这本

忘记在哪找的PDF了,里面是没有目录的,查阅起来很费劲,我花时间整本书过了一遍,手动标注了目录,如图

也算是对整本书的内容了解得七七八八吧,前面对搭建PyQt开发环境什么的,还是有些帮助的,后面各种组件的介绍就没那么详细了,有些有用的东西书里都没有涉及到,还是得依靠Google。so,这本书只能说是矮子里挑高个,差强人意吧~
欢迎交流
程序设计实验室专注于互联网热门新技术探索与团队敏捷开发实践,在公众号「程序设计实验室」后台回复 linux、flutter、c#、netcore、android、kotlin、java、python 等可获取相关技术文章和资料,同时有任何问题都可以在公众号后台留言~

- 博客园:https://www.cnblogs.com/deali/
- 打代码直播间:https://live.bilibili.com/11883038
- 知乎:https://www.zhihu.com/people/dealiaxy
PyQt5开发实践(一、准备篇)的更多相关文章
- vue 2.0 开发实践总结之疑难篇
续上一篇文章:vue2.0 开发实践总结之入门篇 ,如果没有看过的可以移步看一下. 本篇文章目录如下: 1. vue 组件的说明和使用 2. vuex在实际开发中的使用 3. 开发实践总结 1. ...
- vue2.0 开发实践总结之入门篇
vue2.0 据说也出了很久了,博主终于操了一次实刀. 整体项目采用 vue + vue-router + vuex (传说中的vue 全家桶 ),构建工具使用尤大大推出的vue-cli 后续文 ...
- Android游戏开发实践(1)之NDK与JNI开发03
Android游戏开发实践(1)之NDK与JNI开发03 前面已经分享了两篇有关Android平台NDK与JNI开发相关的内容.以下列举前面两篇的链接地址,感兴趣的可以再回顾下.那么,这篇继续这个小专 ...
- TFS 2015 敏捷开发实践 – 在Kanban上运行一个Sprint
前言:在 上一篇 TFS2015敏捷开发实践 中,我们给大家介绍了TFS2015中看板的基本使用和功能,这一篇中我们来看一个具体的场景,如何使用看板来运行一个sprint.Sprint是Scrum对迭 ...
- Android游戏开发实践(1)之NDK与JNI开发02
Android游戏开发实践(1)之NDK与JNI开发02 承接上篇Android游戏开发实践(1)之NDK与JNI开发01分享完JNI的基础和简要开发流程之后,再来分享下在Android环境下的JNI ...
- ASP.NET MVC5 网站开发实践(二) Member区域–管理列表、回复及删除
本来想接着上次把这篇写完的,没想到后来工作的一些事落下了,放假了赶紧补上. 目录: ASP.NET MVC5 网站开发实践 - 概述 ASP.NET MVC5 网站开发实践(一) - 项目框架 ASP ...
- ASP.NET MVC5 网站开发实践(二) Member区域 - 用户部分(3)修改资料、修改密码
在上一篇博客中实现了用户的注销和登录,其实代码里落了点东西,就是用户登录要更新最后一次登录时间和登录IP,这次补上.今天做修改资料和修改密码,TryUpdateModel是新用到的东西. 目录: AS ...
- 移动Web应用开发入门指南——兼容篇
兼容篇 兼容篇是我最想写的一部分,在这之前也总结过很多关于移动开发的兼容问题与解决方案.对于移动Web开发来说,兼容是开发重心,通常要花费30%甚至更多的时间去处理一些兼容问题,甚至时间花掉了,问题依 ...
- 移动Web应用开发入门指南——交互篇
交互篇 从PC到移动端,视觉和交互是用户能直接感受到的差异.在视觉篇中已经提到,移动设备的物理属性一部分影响到视觉,另外一些部分将影响到交互.那么,移动设备影响交互的物理属性都有哪些变化呢?对于这个问 ...
随机推荐
- [C#] 使用 NAudio 实现音频可视化
预览: 捕捉声卡输出: 实现音频可视化, 第一步就是获得音频采样, 这里我们选择使用计算机正在播放的音频作为采样源进行处理: NAudio 中, 可以借助 WasapiLoopbackCapture ...
- 在网页添加 Live2D 看板娘
只需要将以下代码粘贴到 标签中即可 <!--看板娘--> <script src="https://cdn.jsdelivr.net/npm/jquery/dist/jqu ...
- python-内置函数-文件操作
文件操作 用的最多的就是r+,w+和a+都有局限性 w+是先清空,然后再写,之后再读 a+是无论如何调整指针位置,写时都在文件最后追加 而r+可以通过调整指针位置来确定写入的位置 文件操作之with处 ...
- window系统搭建医药后台系统
软件准备: mysql版本: 5.7 jdk版本:1.8 tomcat版本: 9.0 mysql:5.7 第一步:新建Mysql连接 新建Mysql连接 第二步:新建数据库 新建数据库 第三步 ...
- 转: inline关键字使用
1.inline用在函数声明时,还是函数定义时?还是两边都加? 首先,内联函数声明和定义最好在同一个文件中,其它的情况没有实用上的意义. 只要在同一个文件中,声明和定义至少其一加"inlin ...
- Beta_测试说明
Beta阶段测试说明 测试发现的BUG Beta阶段测试BUG: 测试发现的BUG都放在BUG FIX里面 GitHUB issue BUG FIX 后端:实体识别结果重复. 解决:把处理结果的id和 ...
- OO第一单元总结-多项式求导
OO第一单元总结-多项式求导 一.第一.第二次作业总结 因为前两次作业设计复杂度差别不大,因而放在这里统一总结. 基于度量分析程序结构: 前两次作业确实存在缺乏可拓展设计的构想,基本还是面向过程的思维 ...
- JS数组的操作方法汇总
数组的增删 push():添加到最后 pop():取出最后一个 shift():取出第一个 unshift():添加到第一个 splice() : 返回删除的数组,如果没有则为空数组,会改变原数组.可 ...
- xxl-job源码阅读一(客户端)
1.源码入口 使用xxl-job的时候,需要引入一个jar,然后还需要往Spring容器注入XxlJobSpringExecutor <dependency> <groupId> ...
- centos保存rpm到本地以及使用yum完全卸载软件包
目录 保存安装的rpm到本地 方法一: 方法二(推荐): yum卸载软件包包括依赖 保存安装的rpm到本地 方法一: [root@ServerA ~]# vim /etc/yum.conf [main ...