我们非常高兴地宣布基于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。
|
比较一下常规代码和使用新功能后的代码之间的区别:
|
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。选定新的框架后,我们会另写一篇博文。
|
常规代码
|
启用新功能后的代码
|
|
|
像curl一样调用dubbo
服务发布原理观察dubbo服务发布时的启动日志[DUBBO] The service ready on spring started. service: com.alibaba.dubbo.demo.DemoService, dubbo version: 2.0.0, current host: 127.0.0.1
// 第一步:暴露本地服务
[DUBBO] Export dubbo servic