SQLAlchemy mysql方言错误与py2app

时间:2012-05-10 16:06:52

标签: sqlalchemy pyqt py2app

在通过py2app之后,我无法让SQLAlchemy使用我编译的应用程序。我已经在使用py2exe的Windows中成功完成了这项工作。以下是我的设置文件:

APP = ['Blah.py']
DATA_FILES = []
OPTIONS = {'argv_emulation': True,
           'includes': ['sip',
                        'PyQt4._qt',
                        'sqlalchemy.dialects.mysql',
                        'MySQLdb',
                        "gzip"]
           }

setup(
    app=APP,
    data_files=DATA_FILES,
    options={'py2app': OPTIONS},
    setup_requires=['py2app'],
)

这似乎是正确的方法,因为我已经看到人们将它用于sqlite,但是在编译后尝试运行应用程序时仍然会出现此错误:

sqlalchemy.exc.ArgumentError: Could not determine dialect for 'mysql+mysqldb'

我最近一直在尝试使用PyInstaller并且已经陷入了几乎相同的位置,尽管存在以下不同的错误:

 Traceback (most recent call last):
   File "<string>", line 96, in <module>
   File "/Users/tom/Downloads/pyinstaller-pyinstaller-2145d84/PyInstaller/loader/iu.py", line 386, in importHook
     mod = _self_doimport(nm, ctx, fqname)
   File "/Users/tom/Downloads/pyinstaller-pyinstaller-2145d84/PyInstaller/loader/iu.py", line 480, in doimport
     exec co in mod.__dict__
   File "build/bdist.macosx-10.7-intel/egg/MySQLdb/__init__.py", line 19, in <module>
   File "/Users/tom/Downloads/pyinstaller-pyinstaller-2145d84/PyInstaller/loader/iu.py", line 386, in importHook
     mod = _self_doimport(nm, ctx, fqname)
   File "/Users/tom/Downloads/pyinstaller-pyinstaller-2145d84/PyInstaller/loader/iu.py", line 480, in doimport
     exec co in mod.__dict__
   File "build/bdist.macosx-10.7-intel/egg/_mysql.py", line 7, in <module>
   File "build/bdist.macosx-10.7-intel/egg/_mysql.py", line 4, in __bootstrap__
   File "OSX_Installer/Jango/build/pyi.darwin/Jango/out00-PYZ.pyz/pkg_resources", line 882, in resource_filename
   File "OSX_Installer/Jango/build/pyi.darwin/Jango/out00-PYZ.pyz/pkg_resources", line 1352, in get_resource_filename
   File "OSX_Installer/Jango/build/pyi.darwin/Jango/out00-PYZ.pyz/pkg_resources", line 1363, in _extract_resource
 KeyError: '_mysql/_mysql.so'

1 个答案:

答案 0 :(得分:1)

您可能还需要_mysql,其中应包含本机mysql绑定。此外,此绑定需要在目标系统上安装二进制mysql库。

如果您使用纯python mysql库,例如pymysqlMySQL Connector/Python(两者都是supported by sqlalchemy

,您的应用程序可能会更具可移植性