PySide2使用ui界面文件

Python版本3.7
PySide2 Version: 5.14.1
官方文檔:https://doc.qt.io/qtforpython/tutorials/basictutorial/uifiles.html
參考:https://stackoverflow.com/questions/59865610/how-to-translate-a-file-from-ui-to-py-for-pyside2

直接用代碼編寫界面是很繁瑣的荣堰,Qt Creator為我們提供了界面設(shè)計(jì)的功能,如果能在Qt Creator編寫界面送淆,然后轉(zhuǎn)化成py文件宵距,這樣就就能提高我們的效率强缘,使我們更關(guān)注業(yè)務(wù)層面而不是界面的編寫颊乘。下面來看看怎么做到的擂红。

第一步首先是在Qt Creator里面設(shè)計(jì)界面瘪松,這個界面實(shí)際上是一個xml文件暴备。下面是我的一個界面文件悠瞬。如果沒有安裝Qt Creator,可以將下面的文本復(fù)制涯捻,然后保存為mainwindow.ui文件來進(jìn)行測試浅妆。

<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
 <class>MainWindow</class>
 <widget class="QMainWindow" name="MainWindow">
  <property name="geometry">
   <rect>
    <x>0</x>
    <y>0</y>
    <width>400</width>
    <height>300</height>
   </rect>
  </property>
  <property name="windowTitle">
   <string>MainWindow</string>
  </property>
  <widget class="QWidget" name="centralWidget">
   <widget class="QPushButton" name="pushButton">
    <property name="geometry">
     <rect>
      <x>140</x>
      <y>100</y>
      <width>114</width>
      <height>32</height>
     </rect>
    </property>
    <property name="text">
     <string>PushButton</string>
    </property>
   </widget>
  </widget>
  <widget class="QMenuBar" name="menuBar">
   <property name="geometry">
    <rect>
     <x>0</x>
     <y>0</y>
     <width>400</width>
     <height>22</height>
    </rect>
   </property>
  </widget>
  <widget class="QToolBar" name="mainToolBar">
   <attribute name="toolBarArea">
    <enum>TopToolBarArea</enum>
   </attribute>
   <attribute name="toolBarBreak">
    <bool>false</bool>
   </attribute>
  </widget>
  <widget class="QStatusBar" name="statusBar"/>
 </widget>
 <layoutdefault spacing="6" margin="11"/>
 <resources/>
 <connections/>
</ui>

然后官方教程中(上面的官方文檔中)提到了一個工具pyside2-uic,我在命令行運(yùn)行這個工具名提示zsh: command not found: pyside2-uic障癌,然后我又在PySide2安裝包目錄找了半天凌外,確實(shí)沒有這個工具,不知道其他人有沒有這種情況涛浙,但是我卻找到了uic這個工具康辑,我的uic工具位置/usr/local/lib/python3.7/site-packages/PySide2/uic(這個目錄僅供參考摄欲,每個人的PySide2包位置都不一樣),請大家自行搜索pip安裝包的位置疮薇,并找到PySide2這個包胸墙。

如果你電腦有pyside2-uic這個工具,那么使用下面命令進(jìn)行轉(zhuǎn)換按咒。
pyside2-uic mainwindow.ui > ui_mainwindow.py
這個命令是官方給出迟隅,我沒有試過,不知道能不能成功励七。

如果你跟我一樣玻淑,沒有pyside2-uic,只在PySide2包的根目錄下找到了uic的話呀伙,那么執(zhí)行下面這個命令(注意需要在與uic文件同目錄下運(yùn)行补履,如果想全局執(zhí)行,請加入環(huán)境變量中)剿另。
./uic -g python -o ui_mainwindow.py mainwindow.ui
o(output)表示輸出的文件箫锤,g(generator)表示輸出為python格式。

生成的ui_mainwindow.py內(nèi)容如下:

# -*- coding: utf-8 -*-

################################################################################
## Form generated from reading UI file 'mainwindow.ui'
##
## Created by: Qt User Interface Compiler version 5.14.1
##
## WARNING! All changes made in this file will be lost when recompiling UI file!
################################################################################

from PySide2.QtCore import (QCoreApplication, QMetaObject, QObject, QPoint,
    QRect, QSize, QUrl, Qt)
from PySide2.QtGui import (QBrush, QColor, QConicalGradient, QCursor, QFont,
    QFontDatabase, QIcon, QLinearGradient, QPalette, QPainter, QPixmap,
    QRadialGradient)
from PySide2.QtWidgets import *


class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        if MainWindow.objectName():
            MainWindow.setObjectName(u"MainWindow")
        MainWindow.resize(400, 300)
        self.centralWidget = QWidget(MainWindow)
        self.centralWidget.setObjectName(u"centralWidget")
        self.pushButton = QPushButton(self.centralWidget)
        self.pushButton.setObjectName(u"pushButton")
        self.pushButton.setGeometry(QRect(140, 100, 114, 32))
        MainWindow.setCentralWidget(self.centralWidget)
        self.menuBar = QMenuBar(MainWindow)
        self.menuBar.setObjectName(u"menuBar")
        self.menuBar.setGeometry(QRect(0, 0, 400, 22))
        MainWindow.setMenuBar(self.menuBar)
        self.mainToolBar = QToolBar(MainWindow)
        self.mainToolBar.setObjectName(u"mainToolBar")
        MainWindow.addToolBar(Qt.TopToolBarArea, self.mainToolBar)
        self.statusBar = QStatusBar(MainWindow)
        self.statusBar.setObjectName(u"statusBar")
        MainWindow.setStatusBar(self.statusBar)

        self.retranslateUi(MainWindow)

        QMetaObject.connectSlotsByName(MainWindow)
    # setupUi

    def retranslateUi(self, MainWindow):
        MainWindow.setWindowTitle(QCoreApplication.translate("MainWindow", u"MainWindow", None))
        self.pushButton.setText(QCoreApplication.translate("MainWindow", u"PushButton", None))
    # retranslateUi

最后在代碼中引用ui_mainwindow.py文件

from ui_mainwindow import Ui_MainWindow
from PySide2.QtWidgets import QApplication, QMainWindow
import sys


class MainWindow(QMainWindow):
    def __init__(self):
        super(MainWindow, self).__init__()
        self.ui = Ui_MainWindow()
        self.ui.setupUi(self)
        # 界面元素均可通過self.ui這個對象來獲取
        self.ui.pushButton.clicked.connect(self.btn_click)

    def btn_click(self):
        print('clicked')


if __name__ == "__main__":
    app = QApplication(sys.argv)

    window = MainWindow()
    window.show()

    sys.exit(app.exec_())

上面是官方給出的第一個方法雨女,官方還有另一種方法谚攒,使用QtUiTools類。

import sys
from PySide2.QtUiTools import QUiLoader
from PySide2.QtWidgets import QApplication
from PySide2.QtCore import QFile, QIODevice

if __name__ == "__main__":
    app = QApplication(sys.argv)

    ui_file_name = "mainwindow.ui"
    ui_file = QFile(ui_file_name)
    if not ui_file.open(QIODevice.ReadOnly):
        print("Cannot open {}: {}".format(ui_file_name, ui_file.errorString()))
        sys.exit(-1)
    loader = QUiLoader()
    # 載入界面文件
    window = loader.load(ui_file)
    ui_file.close()
    if not window:
        print(loader.errorString())
        sys.exit(-1)
    window.show()

    sys.exit(app.exec_())

不過像上面這樣的話氛堕,引用界面元素好像就沒有智能化提示了馏臭,我比較推薦第一種,注意第一種方式每次Qt Creator里面界面更改保存(一定要記的保存)后讼稚,都需要重新執(zhí)行命令進(jìn)行界面文件的更新括儒。而第二種則不需要。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末锐想,一起剝皮案震驚了整個濱河市帮寻,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌赠摇,老刑警劉巖固逗,帶你破解...
    沈念sama閱讀 206,482評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異藕帜,居然都是意外死亡烫罩,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評論 2 382
  • 文/潘曉璐 我一進(jìn)店門洽故,熙熙樓的掌柜王于貴愁眉苦臉地迎上來贝攒,“玉大人,你說我怎么就攤上這事收津《稣猓” “怎么了浊伙?”我有些...
    開封第一講書人閱讀 152,762評論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長长捧。 經(jīng)常有香客問我嚣鄙,道長,這世上最難降的妖魔是什么串结? 我笑而不...
    開封第一講書人閱讀 55,273評論 1 279
  • 正文 為了忘掉前任哑子,我火速辦了婚禮,結(jié)果婚禮上肌割,老公的妹妹穿的比我還像新娘卧蜓。我一直安慰自己,他們只是感情好把敞,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,289評論 5 373
  • 文/花漫 我一把揭開白布弥奸。 她就那樣靜靜地躺著,像睡著了一般奋早。 火紅的嫁衣襯著肌膚如雪盛霎。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,046評論 1 285
  • 那天耽装,我揣著相機(jī)與錄音愤炸,去河邊找鬼。 笑死掉奄,一個胖子當(dāng)著我的面吹牛规个,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播姓建,決...
    沈念sama閱讀 38,351評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼诞仓,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了引瀑?” 一聲冷哼從身側(cè)響起狂芋,我...
    開封第一講書人閱讀 36,988評論 0 259
  • 序言:老撾萬榮一對情侶失蹤榨馁,失蹤者是張志新(化名)和其女友劉穎憨栽,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體翼虫,經(jīng)...
    沈念sama閱讀 43,476評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡屑柔,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,948評論 2 324
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了珍剑。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片掸宛。...
    茶點(diǎn)故事閱讀 38,064評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖招拙,靈堂內(nèi)的尸體忽然破棺而出唧瘾,到底是詐尸還是另有隱情措译,我是刑警寧澤,帶...
    沈念sama閱讀 33,712評論 4 323
  • 正文 年R本政府宣布饰序,位于F島的核電站领虹,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏求豫。R本人自食惡果不足惜塌衰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,261評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望蝠嘉。 院中可真熱鬧最疆,春花似錦、人聲如沸蚤告。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽杜恰。三九已至蚊逢,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間箫章,已是汗流浹背烙荷。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留檬寂,地道東北人终抽。 一個月前我還...
    沈念sama閱讀 45,511評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像桶至,于是被迫代替她去往敵國和親昼伴。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,802評論 2 345