def refresh(self): #查询可用串口 plist = list(serial.tools.list_ports.comports()) if len(plist)<=0: self.comboBox_uart.clear() self.comboBox_uart.addItem("无串口") else: # 把所有的可用的串口输出到comboBox中去 self.comboBox_uart.clear() for i in range(0, len(plist)): plist_0 = list(plist[i]) self.comboBox_uart.addItem(str(plist_0[0]))使用该函数时,combobox_uart控件无任何显示
时间: 2024-02-14 13:35:17 浏览: 107
您的代码看起来没有问题,但是我猜测问题可能在于您没有在应用程序中正确地调用 refresh() 函数。您需要在适当的时候调用 refresh() 函数来更新 comboBox_uart 控件。
例如,您可以在窗口的初始化函数中调用 refresh() 函数来确保在应用程序启动时更新可用串口列表。或者,您可以在用户执行某些操作(例如按下按钮)时调用 refresh() 函数来手动更新可用串口列表。
如果您已经在应用程序中适当地调用了 refresh() 函数,那么您可能需要检查一下串口是否真的可用。您可以尝试在控制台中打印出 plist 列表来查看可用的串口。另外,您还可以尝试使用其他串口工具来检查串口是否能够正常连接。
相关问题
import sys import serial from PyQt5.QtWidgets import QMainWindow, QApplication from aaa_main import Ui_MainWindow from aaa_child import Ui_ChildWindow import serial.tools.list_ports class Main(QMainWindow, Ui_MainWindow): def __init__(self): super(Main, self).__init__() self.setupUi(self) self.serial = serial.Serial() self.refresh() def refresh(self): plist = list(serial.tools.list_ports.comports()) if len(plist)<=0: self.comboBox_uart.clear() self.comboBox_uart.addItem("无串口") else: self.comboBox_uart.clear() for i in range(0, len(plist)): plist_0 = list(plist[i]) self.comboBox_uart.addItem(str(plist_0[0])) def btn_uart_cb(self): if not self.serial.isOpen(): self.btn_Open.setText("关闭串口") portName = self.comboBox_uart.currentText() baud = self.comboBox_baud.currentText() self.serial = serial.Serial(portName, baud) else: self.serial.close() self.btn_Open.setText("打开串口") class Child(QMainWindow, Ui_ChildWindow): def __init__(self): super(Child, self).__init__() self.setupUi(self) self.pushButton.clicked.connect(self.close) def Open(self): self.show() if __name__ == "__main__": app = QApplication(sys.argv) main = Main() child = Child() main.show() main.pushButton.clicked.connect(child.Open) sys.exit(app.exec_())
这段代码看起来比之前的代码没有问题,但是需要确认 `aaa_main.py` 和 `aaa_child.py` 这两个文件中定义的 `Ui_MainWindow` 和 `Ui_ChildWindow` 类是否存在,以及是否正确导入。如果这些类不存在或者导入错误,也会导致程序崩溃。另外,如果你在程序运行过程中出现错误,可以查看控制台输出的错误信息,以便更好地定位问题。
def repeat_sign(): for i in range(7): self.sign_user_list.append({"avatar": "", "name": "", "userinfo": "", "signed": "", "time": "", "date": ""}) self.avatar_list_func() self.save_sign_pos_info() # 在需要的位置调用该函数 self.timer = QtCore.QTimer() self.timer.timeout.connect(self.face_start) self.avatar_timer_sign = QtCore.QTimer() self.avatar_timer_sign.timeout.connect(self.avatar_timer_func) self.pos_start_m = 0 self.avatar_timer_sign_list = QtCore.QTimer() self.avatar_timer_sign_list.timeout.connect(self.sign_list_mover_func) self.refresh_faceconfig_timer = QtCore.QTimer() self.refresh_faceconfig_timer.timeout.connect(self.refresh_resource) self.timer.start(20) self.avatar_timer_sign.start(2000) # 调用 repeat_sign() 函数 repeat_sign()代码什么意思
这段代码定义了一个名为 "repeat_sign()" 的函数,该函数包含以下步骤:
1. 循环7次,每次将一个字典对象添加到 "sign_user_list" 列表中;
2. 调用 "avatar_list_func()" 函数;
3. 调用 "save_sign_pos_info()" 函数;
4. 创建了一个名为 "timer" 的 QTimer 对象,并将其连接到 "face_start()" 槽函数;
5. 创建了一个名为 "avatar_timer_sign" 的 QTimer 对象,并将其连接到 "avatar_timer_func()" 槽函数;
6. 设置 "pos_start_m" 变量的初始值为0;
7. 创建了一个名为 "avatar_timer_sign_list" 的 QTimer 对象,并将其连接到 "sign_list_mover_func()" 槽函数;
8. 创建了一个名为 "refresh_faceconfig_timer" 的 QTimer 对象,并将其连接到 "refresh_resource()" 槽函数;
9. 启动 "timer" 和 "avatar_timer_sign" 定时器对象,并设置它们的定时器间隔为20ms和2000ms;
10. 最后,调用 "repeat_sign()" 函数本身,以便重复执行上述步骤。
阅读全文
相关推荐














