本文用于記錄在使用 PyQt5 過程中踩過的各種坑滤愕。
1. 打開文件路徑
如果“我的文檔”路徑被修改過(比如從C:\Users\[UserName]\Documents
改為D:\Documents
)荷荤,那么 QFileDialog.getOpenFileName()
將無法直接訪問該路徑疫萤。
doc_dir = QtCore.QStandardPaths.writableLocation(\
QtCore.QStandardPaths.DocumentsLocation)
print (doc_dir) # 這里能正確顯示
file_path = QtWidgets.QFileDialog.getOpenFileName(None,
'Open', doc_dir, 'Text File (*.txt)',
options=QtWidgets.QFileDialog.DontUseNativeDialog)[0]
這個例子中,如果沒有設(shè)置options护锤,那么它打開的將是D:\[UserName]\Documents
送丰。
解決辦法:不用本地窗口。即上面代碼中最后一行的 QFileDialog.DontUseNativeDialog
疗绣。
2. QTabWidget
在 QtDesigner 里面使用自定義的表格(里面含有自定義單元格)并設(shè)置了行數(shù)线召,那么自定義單元格無效。
解決辦法: _________________多矮。
3. 用Pyinstaller打包成exe文件
由于一個未知的原因缓淹,當(dāng)我們用 Pyinstaller 將項目打包成單一 exe 文件后,打開程序時鼠標(biāo)會顯示忙碌狀態(tài)(雖然資源早已加載完成)塔逃,過一會才消失讯壶。
解決辦法:無。除非打包成文件夾而不是單一 exe 文件湾盗,這樣就不會出現(xiàn)這種情況伏蚊。
4. 靈異事件
def __init__(self):
self.widget_prefixes = {'TEXT': 'txt', 'INTEGER': 'sb', 'BOOLEAN': 'cb'}
def _widget(self, objname, datatype):
''' 根據(jù)鍵名找到對應(yīng)的控件,不同數(shù)據(jù)類型對應(yīng)不同控件 '''
return self.findChild(QtWidgets.QWidget, self.widget_prefixes[datatype] + objname)
def setValue(self, obj, typ):
widget = self._widget(obj, typ)
if widget:
# if hasattr(widget, 'setValue'): # 這兩種方法獲得的結(jié)果截然不同淹仑!
widget.setValue(None)
else:
print('Lost type of: %s for widget: %s' % (obj, widget))
5. QImage 上的不明噪點
當(dāng)用 QImage(width, height, format)
或 QImage(QSize, format)
的方法創(chuàng)建透明背景的 QImage 對象時丙挽,圖片上總有一些花花綠綠的噪點。原因是沒仔細(xì)看文檔:
Warning: This will create a QImage with uninitialized data.
解決辦法:這種方法產(chǎn)生的 QImage 是未經(jīng)初始化的匀借,所以使用之前要用 fill 來打掃一遍颜阐,如:img.fill(QColor(0, 0, 0, 0))
。
6. QWidgetAction 上的輸入框不能輸入中文
下圖中吓肋,箭頭指的是一個 QMenu 菜單凳怨,菜單中有一個 QWidgetAction,上面又加了一個輸入框 QLineEdit。這個輸入框無法使用 Windows 10 自帶的中文輸入法輸入漢字肤舞,只能輸入英文字符紫新,或通過 setText()
的方法加入中文字符。
而且這個 bug 不是 PyQt 獨有的李剖,在 C++ 版的 Qt 中也是如此芒率。
解決辦法:顯示菜單后,調(diào)用它的 activateWindow()
方法篙顺,讓菜單獲得焦點即可偶芍。缺點是父窗口會失去焦點,但問題不大德玫。
7. 國際化文本無法翻譯的現(xiàn)象
QTranslator 的實例不能是本地變量(不能用完即刪)匪蟀。