Apscheduler作业序列化无法正常工作

时间:2016-05-24 16:21:42

标签: python python-3.x scheduled-tasks apscheduler

我们正在建立一个基于Apscheduler的调度程序,问题是我们无法序列化作业。

这是我们想要的结构。

类Base,使用其方法,这是要运行的类

class Base(object):
    def __init__(self, bim):
      self.b = bim
      pass

    def print_some(self):
      print "Some bout to go down"

将从中安排类Base执行的类BS

from base import Base
from apscheduler.schedulers.background import BackgroundScheduler
from apscheduler.jobstores.sqlalchemy import SQLAlchemyJobStore
import logging

logging.basicConfig()

jobstores = {'default': SQLAlchemyJobStore(url='url_to_DB')}

class BS(object):
    def __init__(self):
       self.scheduler = BackgroundScheduler()
       self.scheduler.configure(jobstores=jobstores)
       self.scheduler.start()
       self.base = Base()


    def print_some(self):
       print "ngnf"

    def add_job(self):
       self.scheduler.add_job(Base.print_some, 'interval', minutes=1)


BS().add_job()

但是当我运行代码时,我将问题传递给构造函数

ERROR:apscheduler.executors.default:Job "Base.print_some (trigger: interval[0:00:01], next run at: 2016-05-24 18:16:27 CEST)" raised an exception
Traceback (most recent call last):
File "/Library/Python/2.7/site-packages/apscheduler/executors/base.py", line 112, in run_job
retval = job.func(*job.args, **job.kwargs)
TypeError: unbound method print_some() must be called with Base instance as first argument (got nothing instead)

我试过这个

self.scheduler.add_job(Base.print_some, 'interval', args=[Base()], kwargs=dict(self=Base()), seconds=1)

和这个

self.scheduler.add_job(Base.print_some, 'interval', args=[self.base], kwargs=dict(self.base), seconds=1)

他们都没有奏效。

我错过了什么或应该做什么?

1 个答案:

答案 0 :(得分:0)

第二个示例无法正常工作,因为您的位置和关键字参数存在冲突。我假设的第三个不起作用,因为self.base不是可迭代的。 您是否尝试仅将实例作为位置参数传递?