Список зависимостей файла колеса 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