Список зависимостей файла колеса Python
У меня есть файл колеса Python:psutil-5.4.5-cp26-none-linux_x86_64.whl
Как я могу перечислить зависимости, которые имеет это колесо?
7 ответов
как уже упоминалось ранее,.whl
файлы - это просто ZIP-архивы. Вы можете просто открыть их и совать в .
есть инструмент, однако, который может сделать этот ручной процесс немного проще. Вы можете использовать pkginfo, который можно установить, просто используя pip.
$ pip install pkginfo
$ pkginfo -f 'requires_dist' psutil-5.4.5-cp27-none-win32.whl
requires_dist: ["enum34; extra == 'enum'"]
Я просто попытался распаковать (не gunzip) пакет колеса, который у меня лежал. The packagename-version.dist-info/METADATA
файл содержит список Requires-Dist:
записи, содержащие скомпилированные требования из setup.py
.
вы можете установить файл колеса в отдельной виртуальной среде, а затем посмотреть, какие все другие пакеты установлены.
вот минимальный фрагмент, который не требует, чтобы у вас был какой-либо внешний инструмент (unzip, gzip или similars), поэтому он должен работать в обоих *nix/windows:
wheeldeps.py:
import argparse
from zipfile import ZipFile
parser = argparse.ArgumentParser()
parser.add_argument('filename')
args = parser.parse_args()
archive = ZipFile(args.filename)
for f in archive.namelist():
if f.endswith("METADATA"):
for l in archive.open(f).read().decode("utf-8").split("\n"):
if 'requires-dist' in l.lower():
print(l)
пример:
> python wheeldeps.py psutil-5.4.5-cp27-cp27m-win_amd64.whl
Requires-Dist: enum34; extra == 'enum'
это сообщение, которое я где-то нашел. Я скопировал все и отправил себе так что у меня нет источника для этого ответа, но я думаю, что это может помочь. Если кто-нибудь знает источник, я удалю этот пост и свяжу его с этим сообщением.
Installation
$ pip install --upgrade pip # pip-tools needs pip==6.1 or higher (!)
$ pip install pip-tools
Example usage for pip-compile
Suppose you have a Flask project, and want to pin it for production. Write the following line to a file:
# requirements.in
Flask
Now, run pip-compile requirements.in:
$ pip-compile requirements.in
#
# This file is autogenerated by pip-compile
# Make changes in requirements.in, then run this to update:
#
# pip-compile requirements.in
#
flask==0.10.1
itsdangerous==0.24 # via flask
jinja2==2.7.3 # via flask
markupsafe==0.23 # via jinja2
werkzeug==0.10.4 # via flask
And it will produce your requirements.txt, with all the Flask dependencies (and all underlying dependencies) pinned. Put this file under version control as well and periodically re-run pip-compile to update the packages.
Example usage for pip-sync
Now that you have a requirements.txt, you can use pip-sync to update your virtual env to reflect exactly what's in there. Note: this will install/upgrade/uninstall everything necessary to match the requirements.txt contents.
$ pip-sync
Uninstalling flake8-2.4.1:
Successfully uninstalled flake8-2.4.1
Collecting click==4.1
Downloading click-4.1-py2.py3-none-any.whl (62kB)
100% |████████████████████████████████| 65kB 1.8MB/s
Found existing installation: click 4.0
Uninstalling click-4.0:
Successfully uninstalled click-4.0
Successfully installed click-4.1
требование.txt будет иметь все требования, необходимые для пакета.
я использую для установки моих виртуальных envs с pipenv
устанавливает, что pew
как требование. pew
позволяет установить временные вирусные среды, которые удаляются как вы exit
эти специальные виртуальные среды. Так...
создайте новую пустую виртуальную среду и активируйте ее на лету:
pew mktmpenv -p /usr/bin/python3.6
установите пакет:
pip install somedistro
каковы требования вашего дистрибутива (а также требования требования...):
pip list
деактивировать и удалить временную среду.
exit
кроме того, временные виртуальные среды очень полезны при тестировании упаковки.
общий ответ, в unix: используйте strace
найти pid:
ps -C psutil
// Output example 1337
Strace все в процессах
sudo strace -p 1337
только зависимости процесса Strace:
sudo strace -f -e open -p 1337