我一直在与APScheduler合作,在尝试运行代码时,我收到错误"没有触发名称' interval'被发现"
它完全在我的本地计算机上,但可以在我的云计算机上运行。
我尝试过:通过pip,easy_install和手动重新安装apscheduler;升级setuptools;升级所有依赖项。
编辑:代码
if __name__ == '__main__':
scheduler = BlockingScheduler()
scheduler.add_job(SMS, 'interval', minutes=1)
scheduler.start()
print Run Complete
try:
# This is here to simulate application activity (which keeps the main thread alive).
while True:
time.sleep(2)
except (KeyboardInterrupt, SystemExit):
scheduler.shutdown() # Not strictly necessary if daemonic mode is enabled but should be done if possible
LookupError Traceback (most recent call last)
<ipython-input-40-2895cd586d3f> in <module>()
1 if __name__ == '__main__':
2 scheduler = BlockingScheduler()
----> 3 scheduler.add_job(SMS, 'interval', hours=1)
4 scheduler.start()
5 print "Run Complete"
/Users/admin/anaconda/lib/python2.7/site-packages/apscheduler/schedulers/base.pyc in add_job(self, func, trigger, args, kwargs, id, name, misfire_grace_time, coalesce, max_instances, next_run_time, jobstore, executor, replace_existing, **trigger_args)
328
329 job_kwargs = {
--> 330 'trigger': self._create_trigger(trigger, trigger_args),
331 'executor': executor,
332 'func': func,
/Users/admin/anaconda/lib/python2.7/site-packages/apscheduler/schedulers/base.pyc in _create_trigger(self, trigger, trigger_args)
780
781 # Instantiate the trigger class
--> 782 return self._create_plugin_instance('trigger', trigger, trigger_args)
783
784 def _create_lock(self):
/Users/admin/anaconda/lib/python2.7/site-packages/apscheduler/schedulers/base.pyc in _create_plugin_instance(self, type_, alias, constructor_kwargs)
764 raise TypeError('The {0} entry point does not point to a {0} class'.format(type_))
765 else:
--> 766 raise LookupError('No {0} by the name "{1}" was found'.format(type_, alias))
767
768 return plugin_cls(**constructor_kwargs)
LookupError: No trigger by the name "interval" was found
答案 0 :(得分:3)
此问题是由旧版本的setuptools引起的。见https://bitbucket.org/agronholm/apscheduler/issues/77/lookuperror-no-trigger-by-the-name
您可以通过运行sudo pip install --upgrade setuptools
并使用sudo pip install --ignore-installed apscheduler
答案 1 :(得分:1)
其他答案指向环境原因,但也可能是您使用APScheudler的方式。
否则,请验证APScheduler类(scheduler / trigger / jobstore / job)是否正确实例化
LookupError
可能会抛出BaseScheduler
,因为它试图访问调度程序的触发器,作业存储和执行程序。从版本3.6.3开始,它位于base.py _create_plugin_instance()
方法中
最好确认您的文件使用的名称与APScheduler库的名称不同
答案 2 :(得分:0)
我在另一台服务器上使用ipython。我尝试卸载/升级setuptools和APScheduler。然后我将我已经拥有的完全相同的代码复制并粘贴到我在第二台服务器上创建的新笔记本中。
它有效。
答案 3 :(得分:0)
如果您像我一样使用virtualenv 1.11.6,请将其升级到12.0.7以解决此问题。根据此帖子https://bitbucket.org/agronholm/apscheduler/issue/77/lookuperror-no-trigger-by-the-name,您可能还需要升级您的setuptools。
答案 4 :(得分:0)
我在PyInstaller
和cx_Freeze
以及Flask
遇到了冻结环境的问题,尽管虚拟环境没有问题。我的配置和代码如下,
Python 3.6.7 64bit
APScheduler 3.5.3
Flask-APScheduler 1.11.0
Flask 1.0.2
dash 0.32.2
cx-Freeze 5.1.1
PyInstaller 3.4
# The code produces the error
scheduler = APScheduler()
@scheduler.task('interval', id='do_job_1', seconds=30, misfire_grace_time=900)
def job1():
print('Job 1 executed')
按如下所示修复代码后,问题消失了,
from apscheduler.triggers.interval import IntervalTrigger
scheduler = APScheduler()
@scheduler.task(IntervalTrigger(seconds=30), id='do_job_1', misfire_grace_time=900)
def job1():
server.logger.info('Job 1 executed')
答案 5 :(得分:0)
我有一个非常相似的问题。
我的代码不正常工作:
from apscheduler.schedulers.background import BackgroundScheduler
def job1():
print("Job 1 fired")
scheduler = BackgroundScheduler()
scheduler.add_job(job1, 'interval', seconds=2, id="job1")
scheduler.start()
这是我解决的方法:
from apscheduler.schedulers.background import BackgroundScheduler
from apscheduler.triggers.interval import IntervalTrigger
def job1():
print("Job 1 fired")
scheduler = BackgroundScheduler()
scheduler.add_job(job1, IntervalTrigger(), seconds=2, id="job1")
scheduler.start()
我不知道是什么原因引起的。