我们正在建立一个基于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)
他们都没有奏效。
我错过了什么或应该做什么?
答案 0 :(得分:0)
第二个示例无法正常工作,因为您的位置和关键字参数存在冲突。我假设的第三个不起作用,因为self.base不是可迭代的。 您是否尝试仅将实例作为位置参数传递?