当我尝试在我的python代码中导入clr时,我收到以下错误:
*** Error in `python': free(): invalid pointer: 0xb0f1a120 ***
Stacktrace:
at <unknown> <0xffffffff>
at (wrapper managed-to-native) Python.Runtime.Runtime.Py_Initialize () <0xffffffff>
at Python.Runtime.Runtime.Initialize () <0x00023>
at Python.Runtime.PythonEngine.Initialize () <0x00047>
at Python.Runtime.PythonEngine.InitExt () <0x0000b>
at (wrapper runtime-invoke) object.runtime_invoke_void (object,intptr,intptr,intptr) <0xffffffff>
Native stacktrace:
/usr/lib/libmonoboehm-2.0.so.1(+0xcb5f4) [0xb1b5e5f4]
[0xb7745d14]
[0xb7745d1e]
/lib/i386-linux-gnu/libc.so.6(gsignal+0x47) [0xb7592607]
/lib/i386-linux-gnu/libc.so.6(abort+0x143) [0xb7595a33]
/lib/i386-linux-gnu/libc.so.6(+0x68e53) [0xb75cce53]
/lib/i386-linux-gnu/libc.so.6(+0x7333a) [0xb75d733a]
/lib/i386-linux-gnu/libc.so.6(+0x73fad) [0xb75d7fad]
/usr/lib/i386-linux-gnu/libpython2.7.so(PyString_InternInPlace+0x97) [0xb0b3a157]
/usr/lib/i386-linux-gnu/libpython2.7.so(PyString_InternFromString+0x2f) [0xb0ad78ef]
/usr/lib/i386-linux-gnu/libpython2.7.so(PyType_Ready+0xb50) [0xb0b356e0]
/usr/lib/i386-linux-gnu/libpython2.7.so(_Py_ReadyTypes+0xcd) [0xb0b3d47d]
/usr/lib/i386-linux-gnu/libpython2.7.so(Py_InitializeEx+0x6d) [0xb0b5d5dd]
/usr/lib/i386-linux-gnu/libpython2.7.so(Py_Initialize+0x1b) [0xb0b5df7b]
[0xb481553c]
[0xb4814f2c]
[0xb480af98]
[0xb480ae84]
[0xb480af0d]
/usr/lib/libmonoboehm-2.0.so.1(+0x29723) [0xb1abc723]
Debug info from gdb:
Could not attach to process. If your uid matches the uid of the target
process, check the setting of /proc/sys/kernel/yama/ptrace_scope, or try
again as the root user. For more details, see /etc/sysctl.d/10-ptrace.conf
ptrace: Operation not permitted.
No threads.
=================================================================
Got a SIGABRT while executing native code. This usually indicates
a fatal error in the mono runtime or one of the native libraries
used by your application.
=================================================================
我发现了对类似问题的引用(https://mail.python.org/pipermail/pythondotnet/2014-October/001598.html),但我无法弄清楚如何使用npython二进制文件,我不希望在启用共享库的情况下重建python。
任何提示或帮助将不胜感激。
答案 0 :(得分:1)
经过一些痛苦的试验后,我在代码中成功使用import clr
。
首先,我需要以某种方式使用正确的二进制文件,为了实现我使用pythonnet / pythonnet包的git的最新开发源。
您可以尝试:$ sudo pip install --pre pythonnet
下载并安装最新的开发源代码。但请记住,有一些必要条件,所以我附上了travis构建细节
system_info
Build language: python
Operating System: Ubuntu 12.04 LTS
$ python --version
Python 2.7.9
$ pip --version
pip 6.0.7 from /home/travis/virtualenv/python2.7.9/lib/python2.7/site-packages (python 2.7)
$ sudo apt-get install software-properties-common
$ sudo add-apt-repository -y "deb http://archive.ubuntu.com/ubuntu/ trusty main universe"
$ sudo apt-get -qq install mono-devel mono-gmcs mono-xbuild nunit-console
$ sudo mozroots --import --machine --sync
$ yes | sudo certmgr -ssl -m https://go.microsoft.com
$ yes | sudo certmgr -ssl -m https://nugetgallery.blob.core.windows.net
$ yes | sudo certmgr -ssl -m https://nuget.org
$ pip install six
现在通常用pip安装pythonnet应该成功执行,你可以尝试在你的python代码中调用import clr。在我个人的情况下,即使在这种情况下,它也是失败的,尽管安装没有错误。原因是虽然我的python是在没有--enable-shared,运行
的情况下编译的$ python -c 'import sys; from distutils.sysconfig import get_config_var; print(get_config_var("Py_ENABLE_SHARED"))'
返回1,但它应该返回0.
所以我从git https://github.com/pythonnet/pythonnet
下载了最新的dev-source将它放入正确的文件夹后,我编辑了setup.py设置变量 在执行
之后检查共享库为0$ sudo python setup.py install
脚本安装成功且没有错误,我可以在我的python脚本中使用import clr。为确保一切正常运行,您可以运行:
$ python src/tests/runtests.py
答案 1 :(得分:1)
以后参考,Pythonnet issue #119
解决了这个问题添加...
defines.append("PYTHON_WITHOUT_ENABLE_SHARED")
...到setup.py
,然后使用python setup.py install [options]
进行安装,效果与answer相同。