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 22:35:17 浏览: 29
您的代码看起来没有问题,但是我猜测问题可能在于您没有在应用程序中正确地调用 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` 类是否存在,以及是否正确导入。如果这些类不存在或者导入错误,也会导致程序崩溃。另外,如果你在程序运行过程中出现错误,可以查看控制台输出的错误信息,以便更好地定位问题。
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)代码中能否避免重复签到
可以通过添加一个判断条件来避免重复签到,比如在签到时判断当前用户是否已经签到过,如果已经签到过则不执行签到操作,示例代码如下:
```
def sign_in(self):
current_user = self.get_current_user() # 获取当前用户
for user in self.sign_user_list:
if user["name"] == current_user["name"] and user["signed"]:
# 如果当前用户已经签到过,则不执行签到操作
return
# 执行签到操作
self.update_sign_info(current_user)
self.save_sign_pos_info()
```
在这个示例中,我们在签到函数中首先获取当前用户,然后遍历已签到用户列表,如果发现当前用户已经签到过,则直接返回,否则执行签到操作。