BackgroundScheduler定时器创建定时任务
self.log_box = QTextBrowser()
def job(self):
output = os.popen('cd ' + dir_path + ' && svn up ' + dir_path)
# log_box添加日志
self.log_box.setText(output.read())
self.scheduler = BackgroundScheduler()
self.scheduler.add_job(self.job, 'cron', day_of_week=week, hour=time.split(':')[0],
minute=time.split(':')[1])
self.scheduler.start()
BackgroundScheduler定时器一旦启动,进程将会在后台运行,不影响主线程,但是此时通过定时任务去操作qt模块,会失败。job任务中,通过setText向QTextBrowser添加文本,会直接报错,因为定时器和qt属于不同线程。此时需要信号槽来实现线程间通信。
创建信号槽
class SignalDef(QObject):
signal = pyqtSignal(str)
信号槽在创建的时候可以指定信号类型,如果需要指定不同类型:
# 无参数的信号
Signal_NoParameters = PQC.pyqtSignal()
# 带一个参数(整数)的信号
Signal_OneParameter = PQC.pyqtSignal(int)
# 带一个参数(整数或者字符串)的重载版本的信号
Signal_OneParameter_Overload = PQC.pyqtSignal([int],[str])
# 带两个参数(整数,字符串)的信号
Signal_TwoParameters = PQC.pyqtSignal(int,str)
# 带两个参数([整数,整数]或者[整数,字符串])的重载版本的信号
Signal_TwoParameters_Overload = PQC.pyqtSignal([int,int],[int,str])
将信号连接到指定槽函数
self.signal.connect(self.signalCall)
connect后面连接的为接收到信号后的触发函数
发射信号
def job(self):
# os.system('cd ' + dir_path + ' && svn up ' + dir_path)
output = os.popen('cd ' + dir_path + ' && svn up ' + dir_path)
# 发射信号
self.signal.emit(output.read())
这里调整一下之前的job函数,先将log通过emit()函数,传递信号给槽函数signalCall(),然后通过槽函数来操作qt模块,设置QTextBrowser的文本,就可以成功。
def signalCall(self, log):
self.log_box.setText(str(log))