Как я работаю вокруг этой проблемы, создающей virtualenv среду со сделанным на заказ Python?

Я должен выполнить некоторый код машины Linux с предварительно установленным Python 2.3.4. Я не нахожусь в списке sudoers для той машины, таким образом, я создал Python 2.6.4 в (подкаталог в) мой корневой каталог. Затем я попытался использовать virtualenv (впервые), но добрался:

$ Python-2.6.4/python virtualenv/virtualenv.py ENV
New python executable in ENV/bin/python
Could not find platform dependent libraries <exec_prefix>
Consider setting $PYTHONHOME to <prefix>[:<exec_prefix>]
Installing setuptools.........
 Complete output from command /apps/users/dspitzer/ENV/bin/python -c "#!python
\"\"\"Bootstrap setuptoo...

" /apps/users/dspitzer/virtualen...6.egg:
 Could not find platform dependent libraries <exec_prefix>
Consider setting $PYTHONHOME to <prefix>[:<exec_prefix>]
'import site' failed; use -v for traceback
Traceback (most recent call last):
 File "<string>", line 67, in <module>
ImportError: No module named md5
----------------------------------------
...Installing setuptools...done.
Traceback (most recent call last):
 File "virtualenv/virtualenv.py", line 1488, in <module>
  main()
 File "virtualenv/virtualenv.py", line 529, in main
  use_distribute=options.use_distribute)
 File "virtualenv/virtualenv.py", line 619, in create_environment
  install_setuptools(py_executable, unzip=unzip_setuptools)
 File "virtualenv/virtualenv.py", line 361, in install_setuptools
  _install_req(py_executable, unzip)
 File "virtualenv/virtualenv.py", line 337, in _install_req
  cwd=cwd)
 File "virtualenv/virtualenv.py", line 590, in call_subprocess
  % (cmd_desc, proc.returncode))
OSError: Command /apps/users/dspitzer/ENV/bin/python -c "#!python
\"\"\"Bootstrap setuptoo...

" /apps/users/dspitzer/virtualen...6.egg failed with error code 1

Я должен быть установкой PYTHONHOME к некоторому значению? (Я намеренно назвал свой ENV "ENV" из-за отсутствия лучшего имени.)

Не знание, если я могу проигнорировать те ошибки, я пытался установить нос (0.11.1) в мой ENV:

$ cd nose-0.11.1/
$ ls
AUTHORS    doc/               lgpl.txt     nose.egg-info/  selftest.py*
bin/       examples/          MANIFEST.in  nosetests.1     setup.cfg
build/     functional_tests/  NEWS         PKG-INFO        setup.py
CHANGELOG  install-rpm.sh*    nose/        README.txt      unit_tests/
$ ~/ENV/bin/python setup.py install
Could not find platform dependent libraries <exec_prefix>
Consider setting $PYTHONHOME to <prefix>[:<exec_prefix>]
Traceback (most recent call last):
 File "setup.py", line 1, in <module>
  from nose import __version__ as VERSION
 File "/apps/users/dspitzer/nose-0.11.1/nose/__init__.py", line 1, in <module>
  from nose.core import collector, main, run, run_exit, runmodule
 File "/apps/users/dspitzer/nose-0.11.1/nose/core.py", line 3, in <module>
  from __future__ import generators
ImportError: No module named __future__

Совет?

6
задан Daryl Spitzer 17 February 2010 в 02:59
поделиться

2 ответа

Вы действительно запустили "make install" на вашей пользовательской сборке python? Обычно вы хотите сделать что-то вроде

./configure --prefix=/path/to/installdir  (other options)
make
make install

Примечание Префиксом может быть любой каталог, к которому у вас есть полные права на запись, например, я очень часто использую $HOME/apps на shared-hosting окружениях.

Затем запустите /path/to/installdir/bin/python, а не тот, который находится в директории сборки. Это должно создать правильные переменные, после чего вы можете установить virtualenv. Возможно, лучше всего установить virtualenv с помощью его setup.py:

cd virtualenv_source_dir
/path/to/installdir/bin/python setup.py install

Для этого может потребоваться сначала установить setuptools, используя тот же метод.

И наконец:

# Just to be safe
export PATH="/path/to/installdir/bin:$PATH" 

virtualenv ~/ENV
~/ENV/bin/pip install somepackage # (and such)
8
ответ дан 9 December 2019 в 22:33
поделиться

В дополнение к предложению Краста убедиться, что вы действительно установили свой пользовательский скомпилированный Python, вы также должны проверить, что пользовательский Python действительно может найти свои библиотеки. Это намек на сообщение о PYTHONHOME . Ошибки импорта предполагают необходимость установки в .bashrc или соответствующей конфигурации оболочки export PYTHONHOME =/path/to/python _ installation .

Кроме того, при попытке указать virtualenv для использования нестандартной версии python необходимо использовать флаг -p, -python , например,

virtualenv --python=/path/to/python_installation/bin/python myenv

См. также связанный вопрос «Использовать другую версию Python с virtualenv» .

2
ответ дан 9 December 2019 в 22:33
поделиться
Другие вопросы по тегам:

Похожие вопросы: