本文翻译自:Qt for Python 6 released 原文作者:Qt公司研发经理Cristián Maureira-Fredes | ||||
我们非常高兴地宣布基于Qt 6的新版Qt for Python正式发布,同时包含许多新功能🐍。PySide 最初基于Qt 4发布,PySide 2基于Qt 5.12发布。我们决定这次发行版遵循Qt版本编号,也就是说版本跳跃到了PySide6和Shiboken6。 | ||||
让我们一起看一看新版本中的更新内容🎉 | ||||
一般信息 | ||||
我们在项目名称中添加了数字“6”,所以Python Package Index(PyPi)使用起来会有所区别,若使用pip install进行安装,Qt 5.x使用“pyside2/shiboken2”,Qt 6.x 使用“pyside6/shiboken6“,而不是使用pip install pyside6 == 5.15.0或pyside2 == 6.0。 | ||||
您可以通过以下方式安装新版本:pip install pyside6
| ||||
另一个重要的更新是我们支持Python 3.9,并将最低支持的版本提高到3.6。我们在代码库中执行了“ Python 2 exorcism”,删除了该语言不推荐使用的版本。采用新版语言可以有许多好处。它将使您能够在Python代码中使用高效的语言功能,例如f-string,数字文字下划线,变量注释的语法等。 | ||||
PySide6 | ||||
我们在Qt 5.15.2中引入了新的选项__feature__,让您能控制大多数Qt API的命名风格,在camelCase和snake_case之间切换。在Qt 6.0中,您可以使用新功能true_property直接从Python代码访问Qt属性,而不必使用setter和getter。 | ||||
比较一下常规代码和使用新功能后的代码之间的区别:
| ||||
您还将拥有博文《Improved QML Support for Qt for Python 6》所描述的所有新的QML功能。 | ||||
Shiboken6 | ||||
我们可以在新的主版本中清理代码库,所以借此机会检查了Shiboken的方方面面,删除了未使用的功能,添加了新功能,并重组了内部流程,例如 与ApiExtractor 或 CppGenerator的交互。 | ||||
对于生成绑定,我们在类型系统中添加了更多选项,例如,允许在decisor中选择函数重载的使用顺序。我们还增加了声明属性功能,最后为了配合您的非Qt模块,在生成绑定时还可选择自动把Qt模块的camelCase风格名称转化为snake_case风格,从而完善了PySide6中对Qt模块的风格切换功能。 | ||||
在C++支持生成绑定方面,我们改进了与智能指针的交互。我们对其进行了扩展,以处理Qt 6中使用的现代C++特性,例如,从QVector到QList的模板类型别名,新的异常规范关键字,hidden friends运算符等等。 | ||||
合作 | ||||
很多人希望为Qt for Python项目做出贡献,改进我们的文档。然而,当检查我们rst 文档中小修改时会碰到障碍:需要完整构建项目。在文档构建过程中,您需要构建完整的API文档(QDoc及其附属品),这是一个漫长的过程。为了简化该过程,我们引入了一个构建选项来创建本地rst文档,而不包括名为build_rst_docs 的API文档。
| ||||
尽管已在Qt 5.15.2中增加了此项功能,我们仍会关注还能为户做什么,以促进社区贡献的流程。 | ||||
外部扩展模块和商业版 | ||||
由于Qt 扩展模块(例如图像格式、Shader Tools等)的变化,我们正在寻找能更好地通过Python软件包分发它们的选项。分发方式还将影响 Qt 5.15.x中的商业版模块,例如CoAP、MQTT和OpcUA。选定新的框架后,我们会另写一篇博文。 |
08-14
483
08-14
625