gpt4 book ai didi

python - 名称错误 : global name 'create_engine' is not defined [when trying to create a SQLAlchemyJobStore]

转载 作者:可可西里 更新时间:2023-11-01 08:06:25 29 4
gpt4 key购买 nike

我正在尝试添加一个SQLAlchemyJobStore 作业存储(并使其成为默认 作业存储)并在其上存储一些作业。我正在运行 mysql,它有一个名为 jobstore 的数据库。

我有以下程序试图打开 SQLAlchemyJobStore 作业存储到正在运行的 mysql 数据库:

# sqlalchemy.py 
from sqlalchemy import *
from apscheduler.jobstores.sqlalchemy_store import SQLAlchemyJobStore
from apscheduler.scheduler import Scheduler
from datetime import datetime, timedelta
import time

def alarm(time):
print('Alarm! This alarm was scheduled at %s.' % time)

_aps_config = {'standalone': 'True'}
_dbURL = 'mysql://root:<root-password>@localhost/jobstore'

if __name__ == '__main__':

scheduler = Scheduler(_aps_config)
scheduler.add_jobstore(SQLAlchemyJobStore(url=_dbURL), 'default')

alarm_time = datetime.now() + timedelta(seconds=10)
scheduler.add_date_job(alarm, alarm_time, name='alarm1', args=[datetime.now()])
print 'alarms added: ', alarm_time

alarm_time = datetime.now() + timedelta(seconds=15)
scheduler.add_date_job(alarm, alarm_time, name='alarm2', args=[datetime.now()])
print 'alarms added: ', alarm_time

alarm_time = datetime.now() + timedelta(seconds=20)
scheduler.add_date_job(alarm, alarm_time, name='alarm3', args=[datetime.now()])
print 'alarms added: ', alarm_time

try:
scheduler.start()
except (KeyboardInterrupt, SystemExit):
scheduler.shutdown()
pass

当尝试运行上面的代码时,我看到以下内容:

NameError: global name 'create_engine' is not defined

$ python sqlalchemy.py
Traceback (most recent call last):
File "sqlalchemy.py", line 19, in <module>
scheduler.add_jobstore(SQLAlchemyJobStore(url=_dbURL), 'default')
File "/usr/lib/python2.7/site-packages/APScheduler-2.1.0-py2.7.egg/apscheduler/jobstores/sqlalchemy_store.py", line 29, in __init__
self.engine = create_engine(url)
NameError: global name 'create_engine' is not defined
$

我看到 "/usr/lib/python2.7/site-packages/APScheduler-2.1.0-py2.7.egg/apscheduler/jobstores/sqlalchemy_store.py"__init__ 正在尝试 create_engine 但失败了。

 20 class SQLAlchemyJobStore(JobStore):
21 def __init__(self, url=None, engine=None, tablename='apscheduler_jobs',
22 metadata=None, pickle_protocol=pickle.HIGHEST_PROTOCOL):
23 self.jobs = []
24 self.pickle_protocol = pickle_protocol
25
26 if engine:
27 self.engine = engine
28 elif url:
29 self.engine = create_engine(url)

这里出了什么问题?!换句话说,如何使用 APScheduler 创建一个 SQLAlchemyJobStore 并成功地将作业存储在其中?任何示例/代码片段都会有很大帮助!

最佳答案

您的代码似乎没有问题。我尝试运行它并成功完成并显示以下输出:

python jobstore.py
alarms added: 2013-02-07 10:31:10.234000
alarms added: 2013-02-07 10:31:15.240000
alarms added: 2013-02-07 10:31:20.240000

我所做的唯一更改是更新 _dbURL = 'sqlite:///:memory:' 以使用 sqlite 引擎。

请检查您是否安装了 sqlalchemy,它可以通过您的脚本在 PYTHONPATH 中找到。在 python 控制台中运行以下代码,或者最好将其添加到脚本的开头并检查输出。

import sqlalchemy
print sqlalchemy.__version__

更新我重新阅读了您的帖子,并意识到我的测试代码还有一个不同之处——我创建了另一个名称的文件:jobstore.py

我试图将文件重命名为 sqlalchemy.py 并得到同样的异常:

Traceback (most recent call last):
File "C:/stackoverflow/so/sqlalchemy.py", line 22, in <module>
scheduler.add_jobstore(SQLAlchemyJobStore(url=_dbURL), 'default')
File "C:\Progs\Python27\lib\site-packages\apscheduler\jobstores\sqlalchemy_store.py", line 29, in __init__
self.engine = create_engine(url)
NameError: global name 'create_engine' is not defined

Process finished with exit code 1

基本上问题是您的 python 脚本名称与 sqlalchemy 模块名称同名,因此 python 首先加载您的脚本并且无法访问 sqlalchemy 代码。

尝试将脚本名称重命名为 sqlalchemy.py 以外的名称 - 如果您安装了 sqlalchemy 模块,这会有所帮助。

关于python - 名称错误 : global name 'create_engine' is not defined [when trying to create a SQLAlchemyJobStore],我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14745674/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com