Read metadata from Python packages
Project description
=========================
``importlib_metadata``
=========================
``importlib_metadata`` is a library to access the metadata for a Python
package. It is intended to be ported to Python 3.8.
Usage
=====
``importlib_metadata``, unlike its sister packages importlib and
importlib.resources, operates on Python Distribution packages (the
package as installed by pip or similar).
The main feature is the :class:`Distribution` class.
Construct one by passing a top-level module (or package) to
:func:`distribution`:
>>> dist = importlib_resources.distribution(importlib_resources)
From there, the package metadata is available on ``dist.metadata``:
>>> 'Version' in dist.metadata
True
:func:`distribution` also accepts a known distribution package name:
>>> dist = importlib_resources.distribution('importlib_resources')
Package Version
===============
`PEP 396 <https://www.python.org/dev/peps/pep-0396/>` specifies
a convention for presenting a package's version. For many packages,
this version is not defined in code, but is primarily or only defined
in the package metadata. In this case, use of ``importlib_metadata``
can present this version::
__version__ = importlib_metadata.Distribution.from_named_module(__name__).version
Distribution Name
=================
This project introduces the concept of a mapping from an imported module
to its distribution package name. Many times, the name of the imported
module or package matches the distribution package (e.g. requests).
Other times, the imported name and distribution package name differ.
For example, the ``path`` module is the top-level module in the
`path.py <https://pypi.org/project/path.py>`_ distribution package
and in the `setuptools <https://pypi.org/project/setuptools>`_
project, there are two top-level packages, ``setuptools`` and
``pkg_resources``, both sharing the same metadata.
For projects where the name of the top level module does not match
exactly to the distribution package name, those modules should present
a ``__dist_name__`` member with the distribution package name
and this property will be used by importlib_metadata to resolve the
metadata for those Python packages.
Support for Custom Package Installers
=====================================
``importlib_metadata`` provides hooks for third-party package installers
through their declared finders. A custom installer, if it provides its
own finder for installed packages, should also provide on that finder
a ``find_distribution`` callable that when called with
the name of a package will return a ``Distribution`` instance capable
of loading the metadata for that named package (or None if that finder
has no knowledge of that package or its metadata).
Caveats
=======
This project primarily supports third-party packages installed by PyPA
tools (or other conforming packages). It does not support:
- Packages in the stdlib.
- Packages installed without metadata.
- Zip packages.
Project details
===============
* Project home: https://gitlab.com/python-devs/importlib_metadata
* Report bugs at: https://gitlab.com/python-devs/importlib_metadata/issues
* Code hosting: https://gitlab.com/python-devs/importlib_metadata.git
* Documentation: http://importlib_metadata.readthedocs.io/
``importlib_metadata``
=========================
``importlib_metadata`` is a library to access the metadata for a Python
package. It is intended to be ported to Python 3.8.
Usage
=====
``importlib_metadata``, unlike its sister packages importlib and
importlib.resources, operates on Python Distribution packages (the
package as installed by pip or similar).
The main feature is the :class:`Distribution` class.
Construct one by passing a top-level module (or package) to
:func:`distribution`:
>>> dist = importlib_resources.distribution(importlib_resources)
From there, the package metadata is available on ``dist.metadata``:
>>> 'Version' in dist.metadata
True
:func:`distribution` also accepts a known distribution package name:
>>> dist = importlib_resources.distribution('importlib_resources')
Package Version
===============
`PEP 396 <https://www.python.org/dev/peps/pep-0396/>` specifies
a convention for presenting a package's version. For many packages,
this version is not defined in code, but is primarily or only defined
in the package metadata. In this case, use of ``importlib_metadata``
can present this version::
__version__ = importlib_metadata.Distribution.from_named_module(__name__).version
Distribution Name
=================
This project introduces the concept of a mapping from an imported module
to its distribution package name. Many times, the name of the imported
module or package matches the distribution package (e.g. requests).
Other times, the imported name and distribution package name differ.
For example, the ``path`` module is the top-level module in the
`path.py <https://pypi.org/project/path.py>`_ distribution package
and in the `setuptools <https://pypi.org/project/setuptools>`_
project, there are two top-level packages, ``setuptools`` and
``pkg_resources``, both sharing the same metadata.
For projects where the name of the top level module does not match
exactly to the distribution package name, those modules should present
a ``__dist_name__`` member with the distribution package name
and this property will be used by importlib_metadata to resolve the
metadata for those Python packages.
Support for Custom Package Installers
=====================================
``importlib_metadata`` provides hooks for third-party package installers
through their declared finders. A custom installer, if it provides its
own finder for installed packages, should also provide on that finder
a ``find_distribution`` callable that when called with
the name of a package will return a ``Distribution`` instance capable
of loading the metadata for that named package (or None if that finder
has no knowledge of that package or its metadata).
Caveats
=======
This project primarily supports third-party packages installed by PyPA
tools (or other conforming packages). It does not support:
- Packages in the stdlib.
- Packages installed without metadata.
- Zip packages.
Project details
===============
* Project home: https://gitlab.com/python-devs/importlib_metadata
* Report bugs at: https://gitlab.com/python-devs/importlib_metadata/issues
* Code hosting: https://gitlab.com/python-devs/importlib_metadata.git
* Documentation: http://importlib_metadata.readthedocs.io/
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
importlib_metadata-0.1.tar.gz
(12.3 kB
view details)
Built Distribution
File details
Details for the file importlib_metadata-0.1.tar.gz
.
File metadata
- Download URL: importlib_metadata-0.1.tar.gz
- Upload date:
- Size: 12.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.2.0 requests-toolbelt/0.8.0 tqdm/4.25.0 CPython/3.7.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | aeb0d6d24e55fe769576806f299c0c2c4ccf1e1f86c8462e3aa0e85b641f93d8 |
|
MD5 | faa403bfd1f0cc5d1de809149516ef8a |
|
BLAKE2b-256 | 0f975bbd544c2ebec3ce8f583fab94c9c546ca1a9824c41213d4bb905bbf2c13 |
File details
Details for the file importlib_metadata-0.1-py2.py3-none-any.whl
.
File metadata
- Download URL: importlib_metadata-0.1-py2.py3-none-any.whl
- Upload date:
- Size: 10.9 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.2.0 requests-toolbelt/0.8.0 tqdm/4.25.0 CPython/3.7.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 41aa2e4e014750fe46c6e3befe4e8e94b79c05e7ee6876d3fa0d10dd50d312f6 |
|
MD5 | bc4781ea88fddcd5e209e24f20b2232c |
|
BLAKE2b-256 | c9093d1adb7d40d4294a2e8fc664949d788152c1819d63fc131694df8edc0dd8 |