[英]pyqt5 stuck with imports
我正在用 pyqt5 制作一個 GUI,在 1 個文件中我放置了整個 GUI 應用程序,在另一個文件中我放置了用於在 Excel 電子表格中查找姓名和姓氏的代碼。 在 GUI 中,我希望用戶輸入姓名,然后按下從 file2 激活 start() 的搜索按鈕。 在文件 2 中,它搜索電子表格並從中獲取數據,數據需要轉到文件 1 並放入 GUI 的標簽中,但它始終要求提供 self 參數,因為它是 pyqt5 所需的類。
文件 1:
from PyQt5.QtWidgets import QApplication, QMainWindow, QLineEdit, QComboBox, QCheckBox, QSpinBox, QLabel, QMessageBox, QPushButton
import sys
from vind_gebruiker_zaterdag import start
class Window(QMainWindow):
def __init__(self):
super(Window, self).__init__()
self.setWindowTitle("Inschrijven Mosselen")
self.setGeometry(300, 100, 700, 700)
self.initUI()
def initUI(self):
global mg, mgh, mk, mkh, pg, pgh, pk, pkh, dag, betaald, bedrag
mg = "0"
mgh = "0"
mk = "0"
mkh = "0"
pg = "0"
pgh = "0"
pk = "0"
pkh = "0"
brood = None
betaald = "Nee"
found = "Niet gevonden"
self.vind_voornaam = QLineEdit(self)
self.vind_voornaam.move(100, 100)
self.vind_voornaam.setFixedWidth(200)
self.vind_voornaam.setFixedHeight(60)
font = self.vind_voornaam.font()
font.setPointSize(11)
self.vind_voornaam.setFont(font)
self.vind_voornaam.setPlaceholderText("Voornaam")
print(self.vind_voornaam.text())
self.vind_achternaam = QLineEdit(self)
self.vind_achternaam.move(350, 100)
self.vind_achternaam.setFixedWidth(200)
self.vind_achternaam.setFixedHeight(60)
font = self.vind_achternaam.font()
font.setPointSize(11)
self.vind_achternaam.setFont(font)
self.vind_achternaam.setPlaceholderText("achternaam")
print(self.vind_achternaam.text())
self.Input = QLabel("Input", self)
self.Input.move(305, 45)
font = self.Input.font()
font.setPointSize(13)
self.Input.setFont(font)
self.Output = QLabel("Output", self)
self.Output.move(300, 200)
font = self.Output.font()
font.setPointSize(13)
self.Output.setFont(font)
self.search = QPushButton("Zoek", self)
self.search.move(275, 175)
self.search.setFixedWidth(100)
self.search.setFixedHeight(25)
font = self.search.font()
font.setPointSize(12)
self.search.setFont(font)
self.search.clicked.connect(self.clicked)
self.next = QPushButton("Volgende", self)
self.next.move(250, 625)
self.next.setFixedWidth(200)
self.next.setFixedHeight(60)
font = self.next.font()
font.setPointSize(12)
self.next.setFont(font)
self.gevonden = QLabel(f"{found}", self)
self.gevonden.move(285, 235)
font = self.gevonden.font()
font.setPointSize(11)
self.gevonden.setFont(font)
self.mg = QLabel(f"Mosselen groot: {mg}", self)
self.mg.move(50, 250)
font = self.mg.font()
font.setPointSize(11)
self.mg.setFont(font)
self.Subject = QLabel("Vind Inschrijving", self)
self.Subject.move(30, 30)
font = self.Subject.font()
font.setPointSize(15)
self.Subject.setFont(font)
self.update()
def assign(self, mg1, mgh1, mk1, mkh1, pg1, pgh1, pk1, pkh1, betaald1, dag1, bedrag1, found1):
mg = mg1
mgh = mgh1
mk = mk1
mkh = mkh1
pg = pg1
pgh = pgh1
pk = pk1
pkh = pkh1
betaald = betaald1
dag = dag1
bedrag = bedrag1
found = found1
self.mg.setText(mg)
def update(self):
self.Subject.adjustSize()
self.gevonden.adjustSize()
def clicked(self):
start(self.vind_voornaam.text(), self.vind_achternaam.text())
def window():
app = QApplication(sys.argv)
win = Window()
win.show()
sys.exit(app.exec_())
if __name__ == "__main__":
window()
該文件采用姓名和姓氏並在電子表格中搜索它並返回該行中的其他數據。
文件2:
import openpyxl as xl
wb = xl.load_workbook('mosselen 2020.xlsx', data_only=True)
ws1 = wb['ZATERDAG']
ws2 = wb['ZONDAG']
def start(voornaam1, achternaam1):
global found
voornaam = voornaam1
achternaam = achternaam1
active_sheet = ""
row_index = None
min_row = 5
max_row = ws1.max_row - 10
if voornaam == "":
voornaam = None
if achternaam == "":
achternaam = None
for cell in ws1.iter_rows(min_row=min_row, min_col=4, max_col=5, max_row=max_row):
if set((c.value for c in cell)) == {voornaam, achternaam}:
row_index = cell[0].row
print('Gevonden')
found = "Gevonden"
active_sheet = "ZATERDAG"
for cell2 in ws1.iter_rows(min_row=cell[0].row, min_col=6, max_col=33, max_row=cell[0].row):
if voornaam is None:
voornaam = ''
break
if cell2[9].value == 'j':
cell2[27].value = 'al betaald'
else:
cell2[27].value = cell2[27].value
for cell3 in cell2:
if cell3.value is None:
cell3.value = "0"
print(f'besteling:\nMG {cell2[0].value}\nMGH {cell2[1].value}\nMK {cell2[2].value}\nMKH {cell2[3].value}\n'
f'PG {cell2[4].value}\nPGH {cell2[5].value}\nPK {cell2[6].value}\nPKH {cell2[7].value}\nBetaald: {cell2[9].value}\n\nTe betalen: {cell2[27].value}\n ')
mg = cell2[0].value
mgh = cell2[1].value
mk = cell2[2].value
mkh = cell2[3].value
pg = cell2[4].value
pgh = cell2[5].value
pk = cell2[6].value
pkh = cell2[7].value
betaald = cell2[9].value
bedrag = cell2[27].value
dag = active_sheet
print(dag)
assign_var(mg, mgh, mk, mkh, pg, pgh, pk, pkh, betaald, dag, bedrag, found)
max_row = ws1.max_row - 10
for cell in ws2.iter_rows(min_row=min_row, min_col=4, max_col=5, max_row=max_row):
if set((c.value for c in cell)) == {voornaam, achternaam}:
row_index = cell[0].row
print('Gevonden')
found = "Gevonden"
active_sheet = "ZONDAG"
for cell2 in ws2.iter_rows(min_row=cell[0].row, min_col=6, max_col=33, max_row=cell[0].row):
if voornaam is None:
voornaam = ''
break
if cell2[9].value == 'j':
cell2[27].value = 'al betaald'
else:
cell2[27].value = cell2[27].value
for cell3 in cell2:
if cell3.value is None:
cell3.value = "0"
print(f'besteling:\nMG {cell2[0].value}\nMGH {cell2[1].value}\nMK {cell2[2].value}\nMKH {cell2[3].value}\n'
f'PG {cell2[4].value}\nPGH {cell2[5].value}\nPK {cell2[6].value}\nPKH {cell2[7].value}\nBetaald: {cell2[9].value}\n\nTe betalen: {cell2[27].value}\n')
mg = cell2[0].value
mgh = cell2[1].value
mk = cell2[2].value
mkh = cell2[3].value
pg = cell2[4].value
pgh = cell2[5].value
pk = cell2[6].value
pkh = cell2[7].value
betaald = cell2[9].value
bedrag = cell2[27].value
dag = active_sheet
print(dag)
assign_var(mg, mgh, mk, mkh, pg, pgh, pk, pkh, betaald, dag, bedrag, found)
if row_index is not None:
print('{} {} is nummer {}'.format(voornaam, achternaam, row_index - 4))
print()
else:
print('{} {} niet gevonden in Range{}'.format(voornaam, achternaam, (min_row, max_row)))
def assign_var(mg, mgh, mk, mkh, pg, pgh, pk, pkh, betaald, dag, bedrag, found):
from GUI2 import Window
Window.assign(mg, mgh, mk, mkh, pg, pgh, pk, pkh, betaald, dag, bedrag, found)
你的代碼有很多問題。
在您的第二個腳本中,您嘗試訪問Window
類的assign
方法,但這是一個綁定方法。 雖然該方法是該類的成員,但它旨在作為接收類實例作為第一個參數(“ self
”屬性)的方法。
class Test(object):
def method(self):
print(self)
>>> test = Test()
>>> test.method()
<__main__.Test object at 0xb5d5ab0c>
>>> Test.method()
TypeError: unbound method method() must be called with Test instance as first argument (got nothing instead)
為了從實例調用該方法,您需要能夠從第二個腳本訪問該實例。 稍后再談。
有很多關於類和實例如何工作的文章,花一些時間來搜索和研究它們。
global
使用全局變量會導致意想不到且難以檢測的效果,最終您將面臨比您想象的更多的問題。
尤其是在面向對象的編程中,您必須了解每個對象及其成員(變量、函數等)的范圍,以及它們如何在整個項目的層次結構中進行交換。
您還必須考慮全局變量的范圍(在 Python 中,但不僅限於)僅存在於包含它的腳本中。 您不能僅通過從后者執行global x
來從文件B
訪問文件A
的全局變量x
。
根據類/實例概念,有很多關於此的文檔。 你可以從這里開始。
pyuic
生成的代碼來創建你的程序這是一個不幸的常見錯誤。
pyuic
創建的文件不打算作為開始編碼的基礎。 雖然可以檢查它們以獲得有關如何在 Qt 中創建 GUI 的有用見解,但它們應始終被視為資源,與圖像或 json 文件不同。
這樣做的主要原因是,在某些時候您可能需要修改您創建的 UI,並且將新生成的py
文件與現有代碼集成是不必要的麻煩,同時會導致數小時的編輯和頭痛。
這些文件必須作為模塊導入並僅用作模塊。
有多種方法可以使用該代碼,但最常見和建議的是官方文檔中解釋的那些(特別是第三種方法,多重繼承方法)。
注意PyQt5.uic
模塊也有loadUi
函數,可以直接加載.ui
文件。 這有其優點和缺點。 雖然它可以避免每次修改 ui 時都需要重新生成資源文件,但它完全基於相對路徑,並且在必須部署項目時可能很難檢查。
我為您提供了一些半偽代碼,以了解如何實現您的需求。
main.py
:
from PyQt5 import QtWidgets
from ui_window import Ui_Window
from vind_gebruiker_zaterdag import start
class Window(QtWidgets.QMainWindow, Ui_Window):
def __init__(self):
super(Window, self).__init__()
self.setupUi(self)
self.search.clicked.connect(self.clicked)
def clicked(self):
result = start(self.vind_voornaam.text(), self.vind_achternaam.text())
mg = result[0]
mgh = result[1]
# ...
self.mg.setText(mg)
vind_gebruiker_zaterdag.py
:
# ...
def start(voornaam1, achternaam1):
voornaam = voornaam1
achternaam = achternaam1
active_sheet = ""
# ...
return mg, mgh, mk, mkh, pg, pgh, pk, pkh, betaald, dag, bedrag, found
請注意,由於我們沒有編輯 pyuic 生成的代碼,您可以將兩個文件(main 和 vind_gebruiker_zaterdag)整合到一個文件中。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.