QFileDialog的一些静态函数在PyQt中有一个奇怪的历史记录。如果您不了解这段历史,就很难理解PyQt的不同版本之间的差异。在
根本问题很简单。在Python中,如果一个函数需要返回多个值,最常见的解决方案是返回一个元组。但是在C++中,这是不可能的,所以通常的解决方案是提供可以修改的参数。在< >^{}的C++签名是:getSaveFileName(
QWidget * parent = 0, const QString & caption = String(),
const QString & dir = QString(), const QString & filter = QString(),
QString * selectedFilter = 0, Options options = 0)
如您所见,四个QString参数并不完全相同。前三个是const,因此不会被函数修改,但是selectedFilter参数接受一个指向QString的指针,这意味着它可以修改。在
最初,PyQt的主要用途是C++原型(而不是开发Python应用程序),因此API的QT API更加忠实。这意味着,直到PyQT-4.6,只有EME>方法从^ {< CD1>}中获得所选的过滤器,是用C++方式,像这样:
^{pr2}$
实际上,这在当前版本的PyQt4中仍然有效(当然,前提是它启用了QString)。在
多年来,PyQt4稳步引入了许多变化,这些变化逐渐使其对Python越来越友好,但是正如上面的例子所示,这一切都是在不破坏向后兼容性的情况下完成的。当时,更改getSaveFileName的签名以返回元组会导致太多的破坏,因此添加了{}之类的函数作为临时折衷。在
PyQt5没有这样的限制(它甚至不需要再提供QString)。因此(从Python的角度来看)做正确的事情并仅仅从getSaveFileName返回一个元组就成了可能。这一原则现在普遍适用:如果您使用的是PyQt5,并且您在Qt文档中看到一个修改其参数的函数,那么您总是可以期望返回一个元组。在
(PS:PySide的用户——比PyQt年轻得多——从来都不用处理这些问题。对于它们来说,静态QFileDialog函数总是做正确的事情)。在