我使用Ubuntu,并安装了Python 2.7.5和3.4.0。在Python 2.7.5中,我能够成功地分配一个变量x = Value(' I ', 2),但在3.4.0中不能。我得到:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/local/lib/python3.4/multiprocessing/context.py", line 132, in Value
from .sharedctypes import Value
File "/usr/local/lib/python3.4/multiprocessing/sharedctypes.py", line 10, in <
module>
import ctypes
File "/usr/local/lib/python3.4/ctypes/__init__.py", line 7, in <module>
from _ctypes import Union, Structure, Array
ImportError: No module named '_ctypes'
我刚刚通过安装3.4.0的源代码更新到了3.3.2。它安装在/usr/local/lib/python3.4.
我是否正确地更新到Python 3.4 ?
我注意到一件事,Python 3.4安装在usr/local/lib中,而Python 3.3.2仍然安装在usr/lib中,所以它没有被覆盖。
我的解决方案:
用apt-get安装libffi-dev没有帮助。
但是这有帮助:从源代码安装libffi,然后从源代码安装Python 3.8。
我的配置:
Ubuntu 16.04 LTS
Python 3.8.2
循序渐进:
当从Visual Studio Code启动调试器时,我得到了错误消息“ModuleNotFoundError: No module named '_ctypes'”,当运行python3 -c“import sklearn;sklearn.show_versions()”。
从https://github.com/libffi/libffi/releases下载libffi v3.3
安装libtool: sudo apt-get Install libtool
文件README。libffi的Md提到autoconf和automake也是必要的。它们已经安装在我的系统上了。
配置libffi不带docs:
. / configure——disable-docs
做检查
Sudo make install
从https://www.python.org/downloads/下载python 3.8
. / configure
使
做测试
制作安装
之后,我的python安装可以找到_ctypes。
如果你正在做一件没有人会听你说的事情,因为“你做错了”,但你不得不以“错误的方式”做这件事,原因太愚蠢,无法解释,也超出了你的控制能力,你可以试试这个:
获取libffi并按常规方式将其安装到用户安装区。
git clone https://github.com/libffi/libffi.git
cd libffi
./configure --prefix=path/to/your/install/root
make
make install
然后回到你的Python 3源代码,在Python源代码目录的顶层的setup.py中找到这部分代码
ffi_inc = [sysconfig.get_config_var("LIBFFI_INCLUDEDIR")]
if not ffi_inc or ffi_inc[0] == '':
ffi_inc = find_file('ffi.h', [], inc_dirs)
if ffi_inc is not None:
ffi_h = ffi_inc[0] + '/ffi.h'
if not os.path.exists(ffi_h):
ffi_inc = None
print('Header file {} does not exist'.format(ffi_h))
ffi_lib = None
if ffi_inc is not None:
for lib_name in ('ffi', 'ffi_pic'):
if (self.compiler.find_library_file(lib_dirs, lib_name)):
ffi_lib = lib_name
break
ffi_lib="ffi" # --- AND INSERT THIS LINE HERE THAT DOES NOT APPEAR ---
if ffi_inc and ffi_lib:
ext.include_dirs.extend(ffi_inc)
ext.libraries.append(ffi_lib)
self.use_system_libffi = True
并添加我上面标记的注释行。为什么它是必要的,以及为什么没有办法在Linux平台上配置尊重“——without-system-ffi”,也许我会在接下来的几个小时里找到为什么它“不受支持”,但从那以后一切都正常工作。否则,祝你好运……YMMV。
它做什么:只是覆盖那里的逻辑,并导致编译器链接命令添加“-lffi”,这是它真正需要的。如果你的库是用户安装的,那么只要你的PKG_CONFIG_PATH包含路径/到/your/install/root/lib/pkgconfig,它就可以很好地检测到头文件。