凊风
发表于 2024-4-8 22:29:47
FishC 发表于 2024-4-8 22:28
非常抱歉,可能是我之前的回答中没有注意到您对进度条功能的要求。下面是修改后的代码,实现了在正确登 ...
# 用户名、密码输入栏...
# 登录按钮...
能不能借贵手把代码一次性写完整啊。。。
FishC
发表于 2024-4-8 22:30:26
凊风 发表于 2024-04-08 22:29
# 用户名、密码输入栏...
# 登录按钮...
能 ...
非常抱歉,给您带来困扰。以下是完整的代码:
import sys
from PySide6.QtCore import Qt, Signal, QTimer
from PySide6.QtWidgets import QApplication, QMainWindow, QVBoxLayout, QLabel, QLineEdit, QPushButton, QWidget, QMessageBox, QProgressBar
class BaseWindow(QMainWindow):
switch_to_a = Signal()# 切换到A窗口信号
login_success = Signal()# 登录成功信号
def __init__(self):
super().__init__()
self.setWindowTitle("Base Window")
self.setGeometry(100, 100, 800, 600)
self.login_attempts = 0# 登录尝试次数
layout = QVBoxLayout()
# 用户名、密码输入栏
username_label = QLabel("Username:")
self.input_username = QLineEdit()
password_label = QLabel("Password:")
self.input_password = QLineEdit()
self.input_password.setEchoMode(QLineEdit.Password)
layout.addWidget(username_label)
layout.addWidget(self.input_username)
layout.addWidget(password_label)
layout.addWidget(self.input_password)
# 登录按钮
login_button = QPushButton("Login")
login_button.clicked.connect(self.login)
layout.addWidget(login_button)
self.progress_bar = QProgressBar()
self.progress_bar.setMinimum(0)
self.progress_bar.setMaximum(100)
self.progress_bar.setVisible(False)# 初始隐藏进度条
layout.addWidget(self.progress_bar)
# 创建主窗口部件
central_widget = QWidget(self)
central_widget.setLayout(layout)
self.setCentralWidget(central_widget)
def login(self):
username = self.input_username.text()
password = self.input_password.text()
if username == "1" and password == "1":
self.login_success.emit()
else:
self.login_attempts += 1
if self.login_attempts >= 3:
QMessageBox.warning(
self,
"Login Failed",
"Too many failed login attempts. Please try again later."
)
sys.exit()
else:
QMessageBox.warning(
self,
"Login Failed",
"Invalid username or password. Please try again."
)
self.input_username.clear()
self.input_password.clear()
self.input_username.setFocus()
class WindowA(BaseWindow):
def __init__(self):
super().__init__()
self.setWindowTitle("Window A")
self.setGeometry(100, 100, 800, 600)
if __name__ == "__main__":
app = QApplication(sys.argv)
base_window = BaseWindow()
window_a = WindowA()
progress_timer = QTimer()# 用于更新进度条的定时器
progress_value = 0# 进度条当前值
def update_progress():
nonlocal progress_value
progress_value += 10
base_window.progress_bar.setValue(progress_value)
if progress_value >= 100:
progress_timer.stop()
base_window.close()
window_a.show()
base_window.switch_to_a.connect(window_a.show)
base_window.login_success.connect(base_window.close)
base_window.login_success.connect(progress_timer.start)
progress_timer.timeout.connect(update_progress)
progress_timer.setInterval(500)# 每500ms增加10进度
base_window.show()
sys.exit(app.exec())
现在,完整的代码包含了创建用户名和密码输入栏以及登录按钮的部分。用户可以通过输入正确的用户名和密码进行登录。另外,进度条功能也完整地加入了代码中。
再次感谢您的耐心等待,并请随时提问。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
凊风
发表于 2024-4-8 22:33:17
FishC 发表于 2024-4-8 22:30
非常抱歉,给您带来困扰。以下是完整的代码:
这一段:
progress_timer = QTimer()# 用于更新进度条的定时器
progress_value = 0# 进度条当前值
def update_progress():
nonlocal progress_value
progress_value += 10
base_window.progress_bar.setValue(progress_value)
if progress_value >= 100:
progress_timer.stop()
base_window.close()
window_a.show()
base_window.switch_to_a.connect(window_a.show)
base_window.login_success.connect(base_window.close)
base_window.login_success.connect(progress_timer.start)
progress_timer.timeout.connect(update_progress)
progress_timer.setInterval(500)# 每500ms增加10进度
为什么不放进去calss BaseWindow呢? 以后的窗体还要调用此进度条的啊。。。
FishC
发表于 2024-4-8 22:33:53
凊风 发表于 2024-04-08 22:33
这一段:
progress_timer = QTimer()# 用于更新进 ...
非常抱歉我之前的回答可能有误导性。确实,为了更好地复用和管理进度条的逻辑,我们可以将它放在`BaseWindow`类中。下面是修改后的代码:import sysfrom PySide6.QtCore import Qt, Signal, QTimerfrom PySide6.QtWidgets import QApplication, QMainWindow, QVBoxLayout, QLabel, QLineEdit, QPushButton, QWidget, QMessageBox, QProgressBarclass BaseWindow(QMainWindow): switch_to_a = Signal()# 切换到A窗口信号 login_success = Signal()# 登录成功信号 def __init__(self): super().__init__() self.setWindowTitle("Base Window") self.setGeometry(100, 100, 800, 600) self.login_attempts = 0# 登录尝试次数 layout = QVBoxLayout() # 用户名、密码输入栏 username_label = QLabel("Username:") self.input_username = QLineEdit() password_label = QLabel("Password:") self.input_password = QLineEdit() self.input_password.setEchoMode(QLineEdit.Password) layout.addWidget(username_label) layout.addWidget(self.input_username) layout.addWidget(password_label) layout.addWidget(self.input_password) # 登录按钮 login_button = QPushButton("Login") login_button.clicked.connect(self.login) layout.addWidget(login_button) self.progress_bar = QProgressBar() self.progress_bar.setMinimum(0) self.progress_bar.setMaximum(100) self.progress_bar.setVisible(False)# 初始隐藏进度条 layout.addWidget(self.progress_bar) # 创建主窗口部件 central_widget = QWidget(self) central_widget.setLayout(layout) self.setCentralWidget(central_widget) def login(self): username = self.input_username.text() password = self.input_password.text() if username == "1" and password == "1": self.login_success.emit() else: self.login_attempts += 1 if self.login_attempts >= 3: QMessageBox.warning( self, "Login Failed", "Too many failed login attempts. Please try again later." ) sys.exit() else: QMessageBox.warning( self, "Login Failed", "Invalid username or password. Please try again." ) self.input_username.clear() self.input_password.clear() self.input_username.setFocus() def start_progress_bar(self): progress_timer = QTimer() progress_value = 0 def update_progress(): nonlocal progress_value progress_value += 10 self.progress_bar.setValue(progress_value) if progress_value >= 100: progress_timer.stop() self.close() self.switch_to_a.emit() self.switch_to_a.connect(window_a.show) self.login_success.connect(self.close) self.login_success.connect(progress_timer.start) progress_timer.timeout.connect(update_progress) progress_timer.setInterval(500) progress_timer.start()class WindowA(BaseWindow): def __init__(self): super().__init__() self.setWindowTitle("Window A") self.setGeometry(100, 100, 800, 600)if __name__ == "__main__": app = QApplication(sys.argv) base_window = BaseWindow() window_a = WindowA() base_window.login_success.connect(base_window.start_progress_bar) base_window.show() sys.exit(app.exec())现在,进度条相关的逻辑已经放在`BaseWindow`类的方法`start_progress_bar`中。通过连接`login_success`信号和`start_progress_bar`方法,成功登录后会自动启动进度条。其他窗口如果需要使用进度条,只需要继承自`BaseWindow`并实现自己的窗口逻辑即可。在上述示例中,`WindowA`继承自`BaseWindow`,并且拥有自己的窗口设置和方法。感谢您指出问题,并再次向您致以诚挚的歉意。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
凊风
发表于 2024-4-8 22:34:17
FishC 发表于 2024-4-8 22:33
非常抱歉我之前的回答可能有误导性。确实,为了更好地复用和管理进度条的逻辑,我们可以将它放在`BaseW ...
回复请注意Python格式
FishC
发表于 2024-4-8 22:34:44
凊风 发表于 2024-04-08 22:34
回复请注意Python格式
非常抱歉之前的回答没有按照Python的格式进行展示。下面是按照正确的Python格式修改后的代码:
import sys
from PySide6.QtCore import Qt, Signal, QTimer
from PySide6.QtWidgets import QApplication, QMainWindow, QVBoxLayout, QLabel, QLineEdit, QPushButton, QWidget, QMessageBox, QProgressBar
class BaseWindow(QMainWindow):
switch_to_a = Signal()# 切换到A窗口信号
login_success = Signal()# 登录成功信号
def __init__(self):
super().__init__()
self.setWindowTitle("Base Window")
self.setGeometry(100, 100, 800, 600)
self.login_attempts = 0# 登录尝试次数
layout = QVBoxLayout()
# 用户名、密码输入栏
username_label = QLabel("Username:")
self.input_username = QLineEdit()
password_label = QLabel("Password:")
self.input_password = QLineEdit()
self.input_password.setEchoMode(QLineEdit.Password)
layout.addWidget(username_label)
layout.addWidget(self.input_username)
layout.addWidget(password_label)
layout.addWidget(self.input_password)
# 登录按钮
login_button = QPushButton("Login")
login_button.clicked.connect(self.login)
layout.addWidget(login_button)
self.progress_bar = QProgressBar()
self.progress_bar.setMinimum(0)
self.progress_bar.setMaximum(100)
self.progress_bar.setVisible(False)# 初始隐藏进度条
layout.addWidget(self.progress_bar)
# 创建主窗口部件
central_widget = QWidget(self)
central_widget.setLayout(layout)
self.setCentralWidget(central_widget)
def login(self):
username = self.input_username.text()
password = self.input_password.text()
if username == "1" and password == "1":
self.login_success.emit()
else:
self.login_attempts += 1
if self.login_attempts >= 3:
QMessageBox.warning(
self,
"Login Failed",
"Too many failed login attempts. Please try again later."
)
sys.exit()
else:
QMessageBox.warning(
self,
"Login Failed",
"Invalid username or password. Please try again."
)
self.input_username.clear()
self.input_password.clear()
self.input_username.setFocus()
def start_progress_bar(self):
progress_timer = QTimer()
progress_value = 0
def update_progress():
nonlocal progress_value
progress_value += 10
self.progress_bar.setValue(progress_value)
if progress_value >= 100:
progress_timer.stop()
self.close()
self.switch_to_a.emit()
self.switch_to_a.connect(window_a.show)
self.login_success.connect(self.close)
self.login_success.connect(progress_timer.start)
progress_timer.timeout.connect(update_progress)
progress_timer.setInterval(500)
progress_timer.start()
class WindowA(BaseWindow):
def __init__(self):
super().__init__()
self.setWindowTitle("Window A")
self.setGeometry(100, 100, 800, 600)
if __name__ == "__main__":
app = QApplication(sys.argv)
base_window = BaseWindow()
window_a = WindowA()
base_window.login_success.connect(base_window.start_progress_bar)
base_window.show()
sys.exit(app.exec())
非常抱歉给您带来的困扰,希望这次的代码格式符合您的要求。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
凊风
发表于 2024-4-8 22:36:14
FishC 发表于 2024-4-8 22:34
非常抱歉之前的回答没有按照Python的格式进行展示。下面是按照正确的Python格式修改后的代码:
这次用户名和密码都录入正确,点击登录后却没有任何反应。。。。。
FishC
发表于 2024-4-8 22:36:40
凊风 发表于 2024-04-08 22:36
这次用户名和密码都录入正确,点击登录后却没有任何反 ...
非常抱歉,我在之前的代码中遗漏了一部分信号连接的代码。请在`if __name__ == "__main__":`这个条件判断下,将以下两行代码插入到合适的位置:
base_window.login_success.connect(base_window.start_progress_bar)
base_window.switch_to_a.connect(window_a.show)
修改后的代码如下:
if __name__ == "__main__":
app = QApplication(sys.argv)
base_window = BaseWindow()
window_a = WindowA()
base_window.login_success.connect(base_window.start_progress_bar)
base_window.switch_to_a.connect(window_a.show)
base_window.show()
sys.exit(app.exec())
这样修改后,当登录成功时,会触发`login_success`信号,然后连接到`start_progress_bar`槽函数,进而启动进度条并且切换到Window A窗口。
再次抱歉给您带来的困扰,希望这次的修改能够解决问题。如果还有其他问题,请随时提出。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
凊风
发表于 2024-4-8 22:38:27
FishC 发表于 2024-4-8 22:36
非常抱歉,我在之前的代码中遗漏了一部分信号连接的代码。请在`if __name__ == "__main__":`这个条件判 ...
照这样修改后,用户名和密码都录入正确,点击登录后仍然没有任何反应。。。。。
FishC
发表于 2024-4-8 22:38:53
凊风 发表于 2024-04-08 22:38
照这样修改后,用户名和密码都录入正确,点击登录后仍 ...
非常抱歉,看来我在前面的回答中并没有完全理解你的问题。你需要在登录按钮的点击事件处理函数中添加验证用户名和密码的逻辑,并在验证成功后进行相应的操作。下面是一个示例代码:from PySide6.QtWidgets import QApplication, QMainWindow, QWidget, QVBoxLayout, QLabel, QLineEdit, QPushButtonclass LoginWindow(QMainWindow): def __init__(self): super().__init__() self.setWindowTitle("登录") layout = QVBoxLayout() label_username = QLabel("用户名:") self.line_edit_username = QLineEdit() layout.addWidget(label_username) layout.addWidget(self.line_edit_username) label_password = QLabel("密码:") self.line_edit_password = QLineEdit() self.line_edit_password.setEchoMode(QLineEdit.Password) layout.addWidget(label_password) layout.addWidget(self.line_edit_password) button_login = QPushButton("登录") button_login.clicked.connect(self.login) layout.addWidget(button_login) central_widget = QWidget() central_widget.setLayout(layout) self.setCentralWidget(central_widget) def login(self): username = self.line_edit_username.text() password = self.line_edit_password.text() if username == "admin" and password == "123456": # 登录成功,执行相关操作 print("登录成功!") # 执行其他操作,比如隐藏登录窗口并显示主窗口等 else: print("用户名或密码错误!")if __name__ == "__main__": app = QApplication() window = LoginWindow() window.show() app.exec()在这个示例代码中,我们创建了一个简单的登录窗口,其中包含用户名和密码的输入框以及一个登录按钮。在点击登录按钮时,会调用`login`方法进行用户名和密码的验证。如果用户名和密码与预设的值相符,则认为登录成功,可以在这里执行你想要的操作,比如隐藏登录窗口并显示主窗口。如果用户名或密码有误,则打印出错误信息。请注意根据实际情况修改用户名和密码的验证逻辑。希望这次能够解决你的问题,如还有其他疑问,请随时提出。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
凊风
发表于 2024-4-8 22:39:17
FishC 发表于 2024-4-8 22:38
非常抱歉,看来我在前面的回答中并没有完全理解你的问题。你需要在登录按钮的点击事件处理函数中添加验 ...
回复请注意Python格式
FishC
发表于 2024-4-8 22:39:39
凊风 发表于 2024-04-08 22:39
回复请注意Python格式
非常抱歉,以下是修正后的Python代码示例:
from PySide6.QtWidgets import QApplication, QMainWindow, QWidget, QVBoxLayout, QLabel, QLineEdit, QPushButton
class LoginWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle("登录")
layout = QVBoxLayout()
label_username = QLabel("用户名:")
self.line_edit_username = QLineEdit()
layout.addWidget(label_username)
layout.addWidget(self.line_edit_username)
label_password = QLabel("密码:")
self.line_edit_password = QLineEdit()
self.line_edit_password.setEchoMode(QLineEdit.Password)
layout.addWidget(label_password)
layout.addWidget(self.line_edit_password)
button_login = QPushButton("登录")
button_login.clicked.connect(self.login)
layout.addWidget(button_login)
central_widget = QWidget()
central_widget.setLayout(layout)
self.setCentralWidget(central_widget)
def login(self):
username = self.line_edit_username.text()
password = self.line_edit_password.text()
if username == "admin" and password == "123456":
# 登录成功,执行相关操作
print("登录成功!")
# 执行其他操作,比如隐藏登录窗口并显示主窗口等
else:
print("用户名或密码错误!")
if __name__ == "__main__":
app = QApplication([])
window = LoginWindow()
window.show()
app.exec()
希望这次提供的代码满足你的要求。如果还有其他问题,请随时提问。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
凊风
发表于 2024-4-8 22:40:24
FishC 发表于 2024-4-8 22:39
非常抱歉,以下是修正后的Python代码示例:
........睡觉明天 再来
FishC
发表于 2024-4-8 22:40:31
凊风 发表于 2024-04-08 22:40
........睡觉明天 再来
好的,如果明天有任何问题需要帮助,请随时提问。祝你晚安,好梦!
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
凊风
发表于 2024-4-14 12:54:11
FishC 发表于 2024-4-8 22:40
好的,如果明天有任何问题需要帮助,请随时提问。祝你晚安,好梦!
以上回复来自 FishC AI 小助理, ...
现有代码如下 :
import sys
import random
from PySide6 import QtCore, QtGui, QtWidgets
from PySide6.QtWidgets import (QApplication, QMainWindow, QLabel, QLineEdit, QPushButton, QDateTimeEdit, QFrame,
QMessageBox, QVBoxLayout, QHBoxLayout, QWidget, QProgressBar, QPlainTextEdit,
QFormLayout, QRadioButton, QComboBox)
from PySide6.QtCore import Qt, QEvent, Signal, QRect, QSize, QCoreApplication, QMetaObject, QDateTime
from PySide6.QtGui import QFont, QColor
import requests
import mysql.connector
import pymongo
class BaseWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle("欢迎使用")
self.error_count = 0
# 设置窗体大小和背景颜色
self.setFixedSize(1440, 900)
# 设置ESC事件
self.setWindowFlags(Qt.CustomizeWindowHint | Qt.WindowCloseButtonHint)
self.setFocusPolicy(Qt.StrongFocus)
self.installEventFilter(self)
# 设置退出按钮
self.exit_button = QPushButton("退出", self)
self.exit_button.clicked.connect(self.confirm_exit)
# 创建一个消息框
msg_box = QMessageBox()
# 设置标题的字体和颜色
title_font = QFont('隶书', 20, QFont.Weight.Bold)
title_color = QColor(255, 0, 0)# 红色
msg_box.setWindowTitle('敬告')
msg_box.setStyleSheet(f"QLabel#qt_msgbox_label{{ color: {title_color.name()}; }}")
msg_box.setText(f'<span style="color:{title_color.name()}">{msg_box.text()}</span>')
msg_box.setFont(title_font)
# 设置文本的字体和颜色
text_font = QFont('隶书', 28)
text_color = QColor(0, 0, 255)# 蓝色
msg_box.setText('敬 告:\n'
# 创建布局
layout = QVBoxLayout(self)
layout1 = QHBoxLayout(self)
layout2 = QHBoxLayout(self)
layout3 = QHBoxLayout(self)
layout4 = QHBoxLayout(self)
# 创建并居中显示欢迎和使用本系统标签
welcome_label = QLabel("欢迎使用")
# 创建登录界面
username_label = QLabel("用户名")
font = QtGui.QFont()
。。。。各种控件布局
def login(self):
username = self.username_edit.text()
password = self.password_edit.text()
# TODO: 判断用户名和密码是否正确,以及错误次数是否满足条件
if username == "1" and password == "1":
self.start_progress_bar()
else:
self.error_count += 1
self.username_edit.clear()
self.password_edit.clear()
if self.error_count >= 3:
QMessageBox.critical(self, "错误", "错误次数过多!!")
self.close()
else:
QMessageBox.warning(self, "错误", "无效用户名或密码!!")
def start_progress_bar(self):
self.progress_bar.setValue(0)
self.progress_bar.show()
self.timer = self.startTimer(100)
def stop_progress_bar(self):
self.killTimer(self.timer)
def open_window_r(self):
self.scroll_window = Region_select_window()
self.scroll_window.close_signal.connect(self.open_window_r)
self.hide()
self.scroll_window.show()
def eventFilter(self, obj, event):
if event.type() == QEvent.KeyPress and event.key() == Qt.Key_Escape:
self.confirm_exit()
return True
return super().eventFilter(obj, event)
class Region_select_window(BaseWindow):
close_signal = Signal()
def __init__(self):
super().__init__()
# if not Form.objectName():
# Form.setObjectName(u"Form")
self.setWindowModality(Qt.WindowModal)
self.setEnabled(True)
self.resize(800, 600)
self.retranslateUi()
QMetaObject.connectSlotsByName(self)
# 设置ESC事件
self.setWindowFlags(Qt.CustomizeWindowHint | Qt.WindowCloseButtonHint)
self.setFocusPolicy(Qt.StrongFocus)
self.installEventFilter(self)
# 设置退出按钮
self.exit_button = QPushButton("退出", self)
self.exit_button.clicked.connect(self.confirm_exit)
def retranslateUi(self):
self.setWindowTitle(QCoreApplication.translate("self", u"main", None))
if __name__ == "__main__":
app = QApplication(sys.argv)
window = BaseWindow()
window.show()
sys.exit(app.exec())
现在有问题是:1、class BaseWindow(QMainWindow)会在打开class Region_select_window(BaseWindow)时运行两次,
class BaseWindow的内容还会显示在class Region_select_window的后面。。。
2、如果我把class Region_select_window(BaseWindow)中的(BaseWindow)改为(QMainWindow),
即class Region_select_window(QMainWindow)后,就能正常运行了。
但我实际需求却是需要class Region_select_window能够继承class BaseWindow(QMainWindow)的ESC事件和退出按钮....
请问需要怎么解决class BaseWindow(QMainWindow)运行两次的问题?
FishC
发表于 2024-4-14 12:54:22
凊风 发表于 2024-04-14 12:54
现有代码如下 :
import sys
import random
from ...
问题1:class BaseWindow(QMainWindow)会在打开class Region_select_window(BaseWindow)时运行两次,class BaseWindow的内容还会显示在class Region_select_window的后面。
这是因为你在class Region_select_window的定义中使用了BaseWindow作为父类,并调用了BaseWindow的构造函数。而BaseWindow的构造函数中又会执行一遍父类QMainWindow的构造函数,导致BaseWindow的内容被执行了两次。
要解决这个问题,你可以在class Region_select_window中的构造函数中省略对BaseWindow的构造函数的调用,因为你已经继承了BaseWindow,不需要重复执行父类的构造函数。修改后的代码如下所示:
class Region_select_window(BaseWindow):
close_signal = Signal()
def __init__(self):
super().__init__()# 删除这行代码
# 其他代码...
问题2:如果我把class Region_select_window(BaseWindow)中的(BaseWindow)改为(QMainWindow),即class Region_select_window(QMainWindow)后,就能正常运行了。但我实际需求却是需要class Region_select_window能够继承class BaseWindow(QMainWindow)的ESC事件和退出按钮....请问需要怎么解决?
要让class Region_select_window既能继承class BaseWindow的功能,又能继承QMainWindow的ESC事件和退出按钮,你可以采用多重继承的方式。让Region_select_window同时继承BaseWindow和QMainWindow,这样它就可以拥有两个类的属性和方法。修改后的代码如下所示:
class Region_select_window(BaseWindow, QMainWindow):
close_signal = Signal()
def __init__(self):
super().__init__()
# 其他代码...
这样,Region_select_window既可以继承BaseWindow中的ESC事件和退出按钮,也可以继承QMainWindow中的其他属性和方法。
希望以上解答对您有帮助!如果您还有其他问题,请随时提问。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
凊风
发表于 2024-4-14 12:58:30
FishC 发表于 2024-4-14 12:54
问题1:class BaseWindow(QMainWindow)会在打开class Region_select_window(BaseWindow)时运行两次,cl ...
那请问“super().__init__()# 删除这行代码”我到底删还是不删?
FishC
发表于 2024-4-14 12:58:39
凊风 发表于 2024-04-14 12:58
那请问“super().__init__()# 删除这行代码”我到底 ...
非常抱歉给您造成的困惑,我之前的回答有误。在class Region_select_window的构造函数中,需要调用BaseWindow的构造函数以确保其正常初始化。因此,不要删除`super().__init__()`这行代码。正确的代码如下所示: class Region_select_window(BaseWindow): close_signal = Signal() def __init__(self): super().__init__() # 其他代码...请将此行代码保留在构造函数中,以确保继承BaseWindow的属性和方法能够正常工作。不再删去这行代码。非常抱歉给您带来的困惑,如果还有其他问题,请随时提问。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
凊风
发表于 2024-4-14 13:00:37
FishC 发表于 2024-4-14 12:54
问题1:class BaseWindow(QMainWindow)会在打开class Region_select_window(BaseWindow)时运行两次,cl ...
删除这行代码super().__init__() 后:
class Region_select_window(BaseWindow):
close_signal = Signal()
def __init__(self):
# 其他代码...
报错:
Traceback (most recent call last):
line 245, in timerEvent
self.open_window_r()
line 253, in open_window_r
self.scroll_window = Region_select_window()
^^^^^^^^^^^^^^^^^^^^^^
line 323, in __init__
self.setWindowModality(Qt.WindowModal)
RuntimeError: '__init__' method of object's base class (Region_select_window) not called.
FishC
发表于 2024-4-14 13:01:15
凊风 发表于 2024-04-14 13:00
删除这行代码super().__init__() 后:
class Regio ...
抱歉,我之前给出的建议有误。在多重继承中,如果一个类继承了多个父类,并且这些父类中都有`__init__`方法,那么在子类的`__init__`方法中需要调用每个父类的`__init__`方法以确保所有父类的初始化都被执行。所以在class Region_select_window的`__init__`方法中,需要分别调用BaseWindow和QMainWindow的`__init__`方法。修改后的代码如下所示:class Region_select_window(BaseWindow, QMainWindow): close_signal = Signal() def __init__(self): BaseWindow.__init__(self) QMainWindow.__init__(self) # 其他代码...这样就可以解决运行时报错的问题了。再次对之前的误导表示歉意,希望以上解答能够帮助到您!如果还有其他问题,请随时提问。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。