在OS X上构建pymssql

0 投票
2 回答
2055 浏览
提问于 2025-04-16 19:50

我在Mac OS X 10.6.6上尝试安装任何版本的pymssql。无论是1.0.2(稳定版)还是1.9.909(开发版),都能成功构建和安装,但在导入时却出现了以下错误。有没有人成功使用过这个项目?(我现在在用 pyodbc ,但如果能去掉ODBC这一层就更好了

Python 2.6.5 (r265:79359, Mar 24 2010, 01:32:55) 
[GCC 4.0.1 (Apple Inc. build 5493)] on darwin
Type "help", "copyright", "credits" or "license" for more information.

>>> import pymssql
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "_mssql.pxd", line 10, in init pymssql (pymssql.c:8444)
ImportError: dlopen(/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/site-packages/pymssql-1.9.909_dev-py2.6-macosx-10.6-intel.egg/_mssql.so, 2): **Symbol not found: _dbadata**
  Referenced from: /Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/site-packages/pymssql-1.9.909_dev-py2.6-macosx-10.6-intel.egg/_mssql.so
  **Expected in: flat namespace**
 in /Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/site-packages/pymssql-1.9.909_dev-py2.6-macosx-10.6-intel.egg/_mssql.so

2 个回答

1

我在使用tdsver 7.2的时候成功搞定了这个问题,具体可以查看这里

在我的虚拟环境中:

pip install cython >> ok
vim `locate Formula/freetds.rb`
#:s:7.1:8.0:g # Change version 7.1 to 8.0...
#:wq
cd /tmp
wget http://pypi.python.org/packages/source/p/pymssql/pymssql-1.0.2.tar.gz#md5=04dc4aa591acacbc8f183daeea21b690
tar -xzvf pymssql-1.0.2.tar.gz
cd pymssql-1.0.2
python setup.py config
python setup.py build
sudo python setup.py install

最后,成功了!

1

我写了一个fab(fabric)脚本来完成这个任务

import os
from fabric.api import local

def prep_dev_env():
    os.chdir('/tmp/')
    local('cvs -d:pserver:freetds.cvs.sourceforge.net:/cvsroot/freetds login')
    local('cvs -z3 -d:pserver:freetds.cvs.sourceforge.net:/cvsroot/freetds checkout -P freetds')
    os.chdir('/tmp/freetds/')
    local('sudo ./autogen.sh --with-tdsver=7.0')
    local('sudo make')
    local('sudo make install')
    os.chdir('/tmp/')
    #assumes macports is installed
    local('sudo port install mercurial')
    local('hg clone https://code.google.com/p/pymssql/')
    os.chdir('/tmp/pymssql/')
    local('python setup.py config')
    local('python setup.py build')
    local('python setup.py install')
    return

撰写回答