History¶
v9.0.0¶
20 Mar 2026
Deprecations and Removals¶
Added
MetadataNotFound(subclass ofFileNotFoundError) and updatedDistribution.metadata/metadata()to raise it when the metadata files are missing instead of returningNone(python/cpython#143387). (#532)
v8.9.0¶
20 Mar 2026
Features¶
Ported changes from CPython (python/cpython#110937, python/cpython#140141, python/cpython#143658)
v8.8.0¶
19 Mar 2026
Features¶
Removed Python 3.9 compatibility.
v8.7.1¶
21 Dec 2025
Bugfixes¶
v8.7.0¶
27 Apr 2025
Features¶
.metadata()(andDistribution.metadata) can now returnNoneif the metadata directory exists but not metadata file is present. (#493)
Bugfixes¶
Raise consistent ValueError for invalid EntryPoint.value (#518)
v8.6.1¶
20 Jan 2025
Bugfixes¶
Fixed indentation logic to also honor blank lines.
v8.6.0¶
20 Jan 2025
Features¶
Add support for rendering metadata where some fields have newlines (python/cpython#119650).
v8.5.0¶
11 Sep 2024
Features¶
v8.4.0¶
20 Aug 2024
Features¶
Deferred import of inspect for import performance. (#499)
v8.3.0¶
19 Aug 2024
Features¶
Disallow passing of ‘dist’ to EntryPoints.select.
v8.2.0¶
24 Jul 2024
Features¶
Add SimplePath to importlib_metadata.__all__. (#494)
v8.1.0¶
23 Jul 2024
Features¶
Prioritize valid dists to invalid dists when retrieving by name. (#489)
v8.0.0¶
23 Jun 2024
Deprecations and Removals¶
Message.__getitem__ now raises a KeyError on missing keys. (#371)
Removed deprecated support for Distribution subclasses not implementing abstract methods.
v7.2.1¶
23 Jun 2024
Bugfixes¶
When reading installed files from an egg, use
relative_to(walk_up=True)to honor files installed outside of the installation root. (#455)
v7.2.0¶
20 Jun 2024
Features¶
Deferred select imports in for speedup (python/cpython#109829).
Updated fixtures for python/cpython#120801.
v7.1.0¶
20 Mar 2024
Features¶
Improve import time (python/cpython#114664).
Bugfixes¶
v7.0.2¶
07 Mar 2024
No significant changes.
v7.0.1¶
22 Dec 2023
Bugfixes¶
Corrected the interface for SimplePath to encompass the expectations of locate_file and PackagePath.
Fixed type annotations to allow strings.
v7.0.0¶
03 Dec 2023
Deprecations and Removals¶
Removed EntryPoint access by numeric index (tuple behavior).
v6.11.0¶
03 Dec 2023
Features¶
Added
Distribution.originsupplying thedirect_url.jsonin aSimpleNamespace. (#404)
v6.10.0¶
01 Dec 2023
Features¶
Added diagnose script. (#461)
v6.9.0¶
01 Dec 2023
Features¶
Added EntryPoints.__repr__ (#473)
v6.8.0¶
07 Jul 2023
Features¶
Require Python 3.8 or later.
v6.7.0¶
18 Jun 2023
#453: When inferring top-level names that are importable for distributions in
package_distributions, now symlinks to other directories are honored.
v6.6.0¶
22 Apr 2023
#449: Expanded type annotations.
v6.5.1¶
21 Apr 2023
python/cpython#103661: Removed excess error suppression in
_read_files_egginfo_installedand fixed path handling on Windows.
v6.5.0¶
18 Apr 2023
#422: Removed ABC metaclass from
Distributionand instead deprecated construction ofDistributionobjects without concrete methods.
v6.4.1¶
15 Apr 2023
Updated docs with tweaks from upstream CPython.
v6.4.0¶
15 Apr 2023
Consolidated some behaviors in tests around
_path.Added type annotation for
Distribution.read_text.
v6.3.0¶
09 Apr 2023
#115: Support
installed-files.txtforDistribution.fileswhen present.
v6.2.1¶
09 Apr 2023
#442: Fixed issue introduced in v6.1.0 where non-importable names (metadata dirs) began appearing in
packages_distributions.
v6.2.0¶
07 Apr 2023
#384:
PackageMetadatanow stipulates an additionalgetmethod allowing for easy querying of metadata keys that may not be present.
v6.1.0¶
18 Mar 2023
#428:
packages_distributionsnow honors packages and modules with Python modules that not.pysources (e.g..pyc,.so).
v6.0.1¶
18 Mar 2023
#434: Expand protocol for
PackageMetadata.get_allto match the upstream implementation ofemail.message.Message.get_allin python/typeshed#9620.
v6.0.0¶
01 Jan 2023
#419: Declared
Distributionas an abstract class, enforcing definition of abstract methods in instantiated subclasses. It’s no longer possible to instantiate aDistributionor any subclasses unless they define the abstract methods.Please comment in the issue if this change breaks any projects. This change will likely be rolled back if it causes significant disruption.
v5.2.0¶
18 Dec 2022
#371: Deprecated expectation that
PackageMetadata.__getitem__will returnNonefor missing keys. In the future, it will raise aKeyError.
v5.1.0¶
24 Nov 2022
#415: Instrument
SimplePathwith generic support.
v5.0.0¶
01 Oct 2022
v4.13.0¶
01 Oct 2022
#396: Added compatibility for
PathDistributionsoriginating from Python 3.8 and 3.9.
v4.12.0¶
25 Jun 2022
py-93259: Now raise
ValueErrorwhenNoneor an empty string are passed toDistribution.from_name(and other callers).
v4.11.4¶
21 May 2022
#379: In
PathDistribution._name_from_stem, avoid including parts of the extension in the result.#381: In
PathDistribution._normalized_name, ensure names loaded from the stem of the filename are also normalized, ensuring duplicate entry points by packages varying only by non-normalized name are hidden.
Note (#459): This change had a backward-incompatible effect for any installers that created metadata in the filesystem with dashes in the package names (not replaced by underscores).
v4.11.3¶
13 Mar 2022
#372: Removed cast of path items in FastPath, not needed.
v4.11.2¶
26 Feb 2022
#369: Fixed bug where
EntryPoint.extraswas returning match objects and not the extras strings.
v4.11.1¶
14 Feb 2022
#367: In
Distribution.requiresfor egg-info, ifrequires.txtis empty, return an empty list.
v4.11.0¶
10 Feb 2022
bpo-46246: Added
__slots__toEntryPoints.
v4.10.2¶
v4.10.1¶
16 Jan 2022
v2.1.3¶
16 Jan 2022
#361: Avoid potential REDoS in
EntryPoint.pattern.
v4.10.0¶
19 Dec 2021
#354: Removed
Distribution._localfactory. This functionality was created as a demonstration of the possible implementation. Now, the pep517 package provides this functionality directly through pep517.meta.load.
v4.9.0¶
16 Dec 2021
Require Python 3.7 or later.
v4.8.3¶
16 Dec 2021
#357: Fixed requirement generation from egg-info when a URL requirement is given.
v4.8.2¶
08 Nov 2021
v2.1.2¶
08 Nov 2021
#353: Fixed discovery of distributions when path is empty.
v4.8.1¶
29 Aug 2021
#348: Restored support for
EntryPointaccess by item, deprecating support in the process. Users are advised to use direct member access instead of item-based access:- ep[0] -> ep.name - ep[1] -> ep.value - ep[2] -> ep.group - ep[:] -> ep.name, ep.value, ep.group
v4.8.0¶
28 Aug 2021
#337: Rewrote
EntryPointas a simple class, still immutable and still with the attributes, but without any expectation fornamedtuplefunctionality such as_asdict.
v4.7.1¶
26 Aug 2021
#344: Fixed regression in
packages_distributionswhen neither top-level.txt nor a files manifest is present.
v4.7.0¶
25 Aug 2021
#330: In
packages_distributions, now infer top-level names from.files()when atop-level.txt(Setuptools-specific metadata) is not present.
v4.6.4¶
13 Aug 2021
#334: Correct
SimplePathprotocol to matchpathlibprotocol for__truediv__.
v4.6.3¶
31 Jul 2021
Moved workaround for #327 to
_compatmodule.
v4.6.2¶
30 Jul 2021
bpo-44784: Avoid errors in test suite when DeprecationWarnings are treated as errors.
v4.6.1¶
04 Jul 2021
#327: Deprecation warnings now honor call stack variance on PyPy.
v4.6.0¶
27 Jun 2021
#326: Performance tests now rely on pytest-perf. To disable these tests, which require network access and a git checkout, pass
-p no:perfto pytest.
v4.5.0¶
03 Jun 2021
#319: Remove
SelectableGroupsdeprecation exception for flake8.
v4.4.0¶
31 May 2021
#300: Restore compatibility in the result from
Distribution.entry_points(EntryPoints) to honor expectations in older implementations and issuing deprecation warnings for these cases:EntryPointsobjects are once again mutable, allowing forsort()and other list-based mutation operations. Avoid deprecation warnings by casting to a mutable sequence (e.g.list(dist.entry_points).sort()).EntryPointsresults once again allow for access by index. To avoid deprecation warnings, cast the result to a Sequence first (e.g.tuple(dist.entry_points)[0]).
v4.3.1¶
28 May 2021
#320: Fix issue where normalized name for eggs was incorrectly solicited, leading to metadata being unavailable for eggs.
v4.3.0¶
27 May 2021
#317: De-duplication of distributions no longer requires loading the full metadata for
PathDistributionobjects, entry point loading performance by ~10x.
v4.2.0¶
26 May 2021
Prefer f-strings to
.formatcalls.
v4.1.0¶
26 May 2021
v4.0.1¶
20 Apr 2021
#306: Clearer guidance about compatibility in readme.
v4.0.0¶
18 Apr 2021
#304:
PackageMetadataas returned bymetadata()andDistribution.metadata()now provides normalized metadata honoring PEP 566:If a long description is provided in the payload of the RFC 822 value, it can be retrieved as the
Descriptionfield.Any multi-line values in the metadata will be returned as such.
For any multi-line values, line continuation characters are removed. This backward-incompatible change means that any projects relying on the RFC 822 line continuation characters being present must be tolerant to them having been removed.
Add a
jsonproperty that provides the metadata converted to a JSON-compatible form per PEP 566.
v3.10.1¶
12 Apr 2021
Minor tweaks from CPython.
v3.10.0¶
29 Mar 2021
#295: Internal refactoring to unify section parsing logic.
v3.9.1¶
29 Mar 2021
v3.9.0¶
28 Mar 2021
Use of Mapping (dict) interfaces on
SelectableGroupsis now flagged as deprecated. Instead, users are advised to use the select interface for future compatibility.Suppress the warning with this filter:
ignore:SelectableGroups dict interface.Or with this invocation in the Python environment:
warnings.filterwarnings('ignore', 'SelectableGroups dict interface').Preferably, switch to the
selectinterface introduced in 3.7.0. See the entry points documentation and changelog for the 3.6 release below for more detail.For some use-cases, especially those that rely on
importlib.metadatain Python 3.8 and 3.9 or those relying on olderimportlib_metadata(especially on Python 3.5 and earlier), backports.entry_points_selectable was created to ease the transition. Please have a look at that project if simply relying on importlib_metadata 3.6+ is not straightforward. Background in #298.#283: Entry point parsing no longer relies on ConfigParser and instead uses a custom, one-pass parser to load the config, resulting in a ~20% performance improvement when loading entry points.
v3.8.2¶
28 Mar 2021
#293: Re-enabled lazy evaluation of path lookup through a FreezableDefaultDict.
v3.8.1¶
27 Mar 2021
#293: Workaround for error in distribution search.
v3.8.0¶
26 Mar 2021
#290: Add mtime-based caching for
FastPathand its lookups, dramatically increasing performance for repeated distribution lookups.
v3.7.3¶
14 Mar 2021
Docs enhancements and cleanup following review in GH-24782.
v3.7.2¶
07 Mar 2021
Cleaned up cruft in entry_points docstring.
v3.7.1¶
07 Mar 2021
Internal refactoring to facilitate
entry_points() -> dictdeprecation.
v3.7.0¶
24 Feb 2021
#131: Added
packages_distributionsto conveniently resolve a top-level package or module to its distribution(s).
v3.6.0¶
23 Feb 2021
#284: Introduces new
EntryPointsobject, a tuple ofEntryPointobjects but with convenience properties for selecting and inspecting the results:.select()acceptsgroupornamekeyword parameters and returns a newEntryPointstuple with only those that match the selection..groupsproperty presents all of the group names..namesproperty presents the names of the entry points.Item access (e.g.
eps[name]) retrieves a single entry point by name.
entry_pointsnow accepts “selection parameters”, same asEntryPoint.select().entry_points()now provides a future-compatibleSelectableGroupsobject that supplies the above interface (except item access) but remains a dict for compatibility.In the future,
entry_points()will return anEntryPointsobject for all entry points.If passing selection parameters to
entry_points, the future behavior is invoked and anEntryPointsis the result.#284: Construction of entry points using
dict([EntryPoint, ...])is now deprecated and raises an appropriate DeprecationWarning and will be removed in a future version.#300:
Distribution.entry_pointsnow presents as anEntryPointsobject and access by index is no longer allowed. If access by index is required, cast to a sequence first.
v3.5.0¶
21 Feb 2021
#280:
entry_pointsnow only returns entry points for unique distributions (by name).
v3.4.0¶
10 Jan 2021
v3.3.0¶
13 Dec 2020
#265:
EntryPointobjects now expose a.distobject referencing theDistributionwhen constructed from a Distribution.
v3.2.0¶
13 Dec 2020
The object returned by
metadata()now has a formally-defined protocol calledPackageMetadatawith declared support for the.get_all()method. Fixes #126.
v3.1.1¶
01 Dec 2020
v2.1.1¶
01 Dec 2020
#261: Restored compatibility for package discovery for metadata without version in the name and for legacy eggs.
v3.1.0¶
23 Nov 2020
Merge with 2.1.0.
v2.1.0¶
23 Nov 2020
#253: When querying for package metadata, the lookup now honors package normalization rules.
v3.0.0¶
22 Nov 2020
Require Python 3.6 or later.
v2.0.0¶
26 Jun 2020
importlib_metadatano longer presents a__version__attribute. Consumers wishing to resolve the version of the package should query it directly withimportlib_metadata.version('importlib-metadata'). Closes #71.
v1.7.0¶
14 Jun 2020
PathNotFoundErrornow has a custom__str__mentioning “package metadata” being missing to help guide users to the cause when the package is installed but no metadata is present. Closes #124.
v1.6.1¶
05 Jun 2020
Added
Distribution._local()as a provisional demonstration of how to load metadata for a local package. Implicitly requires that pep517 is installed. Ref #42.Ensure inputs to FastPath are Unicode. Closes #121.
Tests now rely on
importlib.resources.files(and backport) instead of the olderpathfunction.Support any iterable from
find_distributions. Closes #122.
v1.6.0¶
27 Mar 2020
Added
moduleandattrattributes toEntryPoint
v1.5.2¶
26 Mar 2020
Fix redundant entries from
FastPath.zip_children. Closes #117.
v1.5.1¶
25 Mar 2020
Improve reliability and consistency of compatibility imports for contextlib and pathlib when running tests. Closes #116.
v1.5.0¶
29 Jan 2020
Additional performance optimizations in FastPath now saves an additional 20% on a typical call.
Correct for issue where PyOxidizer finder has no
__module__attribute. Closes #110.
v1.4.0¶
10 Jan 2020
v1.3.0¶
10 Dec 2019
Improve custom finders documentation. Closes #105.
v1.2.0¶
04 Dec 2019
Once again, drop support for Python 3.4. Ref #104.
v1.1.3¶
04 Dec 2019
Restored support for Python 3.4 due to improper version compatibility declarations in the v1.1.0 and v1.1.1 releases. Closes #104.
v1.1.2¶
04 Dec 2019
Repaired project metadata to correctly declare the
python_requiresdirective. Closes #103.
v1.1.1¶
04 Dec 2019
Fixed
repr(EntryPoint)on PyPy 3 also. Closes #102.
v1.1.0¶
01 Dec 2019
v1.0.0¶
30 Nov 2019
Project adopts semver for versioning.
Removed compatibility shim introduced in 0.23.
For better compatibility with the stdlib implementation and to avoid the same distributions being discovered by the stdlib and backport implementations, the backport now disables the stdlib DistributionFinder during initialization (import time). Closes #91 and closes #100.
0.23¶
16 Sep 2019
Added a compatibility shim to prevent failures on beta releases of Python before the signature changed to accept the “context” parameter on find_distributions. This workaround will have a limited lifespan, not to extend beyond release of Python 3.8 final.
0.22¶
11 Sep 2019
Renamed
packageparameter todistribution_nameas recommended in the following functions:distribution,metadata,version,files, andrequires. This backward-incompatible change is expected to have little impact as these functions are assumed to be primarily used with positional parameters.
0.21¶
10 Sep 2019
importlib.metadatanow exposes theDistributionFindermetaclass and references it in the docs for extending the search algorithm.Add
Distribution.atfor constructing a Distribution object from a known metadata directory on the file system. Closes #80.Distribution finders now receive a context object that supplies
.pathand.nameproperties. This change introduces a fundamental backward incompatibility for any projects implementing afind_distributionsmethod on aMetaPathFinder. This new layer of abstraction allows this context to be supplied directly or constructed on demand and opens the opportunity for afind_distributionsmethod to solicit additional context from the caller. Closes #85.
0.20¶
02 Sep 2019
0.19¶
28 Jul 2019
Restrain over-eager egg metadata resolution.
Add support for entry points with colons in the name. Closes #75.
0.18¶
09 Jun 2019
0.17¶
29 May 2019
Fix a permission problem in the tests on Windows.
0.16¶
29 May 2019
Don’t crash if there exists an EGG-INFO directory on sys.path.
0.15¶
24 May 2019
Fix documentation.
0.14¶
24 May 2019
Removed
local_distributionfunction from the API. This backward-incompatible change removes this behavior summarily. Projects should remove their reliance on this behavior. A replacement behavior is under review in the pep517 project. Closes #42.
0.13¶
18 May 2019
0.12¶
14 May 2019
Add support for eggs. !65; Closes #19.
0.11¶
09 May 2019
0.10¶
07 May 2019
0.9¶
25 Mar 2019
0.8¶
01 Jan 2019
This library can now discover/enumerate all installed packages. This backward-incompatible change alters the protocol finders must implement to support distribution package discovery. Closes #24.
The signature of
find_distributions()on custom installer finders should now accept two parameters,nameandpathand these parameters must supply defaults.The
entry_points()method no longer accepts a package name but instead returns all entry points in a dictionary keyed by theEntryPoint.group. Theresolvemethod has been removed. Instead, callEntryPoint.load(), which has the same semantics aspkg_resourcesandentrypoints. This is a backward incompatible change.Metadata is now always returned as Unicode text regardless of Python version. Closes #29.
This library can now discover metadata for a ‘local’ package (found in the current-working directory). Closes #27.
Added
files()function for resolving files from a distribution.Added a new
requires()function, which returns the requirements for a package suitable for parsing bypackaging.requirements.Requirement. Closes #18.The top-level
read_text()function has been removed. UsePackagePath.read_text()on instances returned by thefiles()function. This is a backward incompatible change.Release dates are now automatically injected into the changelog based on SCM tags.
0.7¶
27 Nov 2018
Fixed issue where packages with dashes in their names would not be discovered. Closes #21.
Distribution lookup is now case-insensitive. Closes #20.
Wheel distributions can no longer be discovered by their module name. Like Path distributions, they must be indicated by their distribution package name.
0.6¶
07 Oct 2018
Removed
importlib_metadata.distributionfunction. Now the public interface is primarily the utility functions exposed inimportlib_metadata.__all__. Closes #14.Added two new utility functions
read_textandmetadata.
0.5¶
18 Sep 2018
Updated README and removed details about Distribution class, now considered private. Closes #15.
Added test suite support for Python 3.4+.
Fixed SyntaxErrors on Python 3.4 and 3.5. !12
Fixed errors on Windows joining Path elements. !15
0.4¶
14 Sep 2018
Housekeeping.
0.3¶
14 Sep 2018
0.2¶
11 Sep 2018
0.1¶
09 Sep 2018
Initial release.