Python 名称错误:全局名称';创建引擎&x27;未定义[尝试创建SQLAlchemyJobStore时]

Python 名称错误:全局名称';创建引擎&x27;未定义[尝试创建SQLAlchemyJobStore时],python,mysql,sqlalchemy,scheduler,apscheduler,Python,Mysql,Sqlalchemy,Scheduler,Apscheduler,我正在尝试添加一个SQLAlchemyJobStorejobstore(并将其设置为默认值jobstore)并在其上存储一些作业。我正在运行mysql,它有一个名为jobstore的数据库 我有以下程序,它试图打开一个SQLAlchemyJobStorejobstore到正在运行的mysqldb: # sqlalchemy.py from sqlalchemy import * from apscheduler.jobstores.sqlalchemy_store import SQLAlch

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

我有以下程序,它试图打开一个
SQLAlchemyJobStore
jobstore到正在运行的
mysql
db:

# 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

这里怎么了?!换句话说,如何使用
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
我所做的唯一更改是更新
\u 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
回溯(最近一次呼叫最后一次):
文件“C:/stackoverflow/so/sqlalchemy.py”,第22行,在
add_jobstore(SQLAlchemyJobStore(url=_dbURL),'default')
文件“C:\Progs\Python27\lib\site packages\apscheduler\jobstores\sqlalchemy\u store.py”,第29行,在u init中__
self.engine=创建引擎(url)
NameError:未定义全局名称“创建引擎”
进程已完成,退出代码为1
基本上,问题在于python脚本名与sqlalchemy模块名同名,因此python首先加载脚本,无法访问sqlalchemy代码


尝试将脚本名称重命名为其他名称,然后
sqlalchemy.py
——如果您安装了sqlalchemy模块,这将有所帮助。

您是正确的;APScheduler google groups上也讨论过同样的问题,社区的一位先生也强调了同样的问题!谢谢+谢谢你救了我一天
import sqlalchemy
print sqlalchemy.__version__ 
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