Jump to content

Python Package Index

From Wikipedia, the free encyclopedia
PyPI
Type of site
Software repository
Available inMultilingual
OwnerPython Software Foundation
URLpypi.org
Launched2003[1]
Current statusActive
Written inVarious

The Python Package Index, abbreviated as PyPI (/ˌppiˈ/) and also known as the Cheese Shop (a reference to the Monty Python's Flying Circus sketch "Cheese Shop"),[2]: 8 [3]: 742  is the official third-party software repository for Python.[4] It is analogous to the CPAN repository for Perl[5]: 36  and to the CRAN repository for R. PyPI is run by the Python Software Foundation, a charity. Some package managers, including pip, use PyPI as the default source for packages and their dependencies.[6][7]

As of 6 May 2024, more than 530,000 Python packages are available.

PyPI primarily hosts Python packages in the form of source archives, called "sdists", or of "wheels"[8] that may contain binary modules from a compiled language.

PyPI as an index allows users to search for packages by keywords or by filters against their metadata, such as free software license or compatibility with POSIX.[9] A single entry on PyPI is able to store, aside from just a package and its metadata, previous releases of the package, precompiled wheels (e.g. containing DLLs on Windows), as well as different forms for different operating systems and Python versions.

History

[edit]

The Python Distribution Utilities (distutils) Python module was first added to the Python standard library in the 1.6.1 release, in September 2000, and in the 2.0 release, in October 2000, nine years after the first Python release in February 1991, with the goal of simplifying the process of installing third-party Python packages.[10][11]

However, distutils only provided the tools for packaging Python code, and no more. It was able to collect and distribute metadata but did not use it for other purposes.[12] Python still lacked a centralised catalog for packages on the internet. PEP 241, a proposal to standardize metadata for indexes, was finalized in March 2001.[13] A proposal to create a comprehensive centralised catalog, hosted at the python.org domain, was later finalized in November 2002.[4][12]

On 16 April 2018, all PyPI traffic began being served by a more modern website platform: Warehouse. The legacy website was turned off at the end of that month.[14][15] All existing packages were migrated to the new platform with their histories preserved.[16]

In May 2023 the Python Software Foundation reported that the United States Department of Justice had subpoenaed the user data of five PyPI contributors.[17][18] A representative of the organization further explained that they expect privacy for contributors, but they also comply with the law and court orders, and for this reason turned over the data which the government requested.[17]

Notes

[edit]

References

[edit]
  1. ^ "Packaging History". Python Packaging Authority — PyPA documentation.
  2. ^ Lutz, Mark (2006). Programming Python. Vol. 10 (3 ed.). O'Reilly Media, Inc. ISBN 9780596009250.
  3. ^ Ramalho, Luciano (2015). Fluent Python. O'Reilly Media, Inc. ISBN 9781491946268.
  4. ^ a b Hylton, Jeremy (24 September 2003). "Python Package Index Tutorial". Jeremy Hylton. Archived from the original on 21 May 2012. Retrieved 22 April 2012.
  5. ^ Barry, Paul (2010). Head First Python. O'Reilly Media, Inc. ISBN 978-1-4493-8267-4.
  6. ^ "Usage". pip 1.1.post1 documentation. The pip developers. Archived from the original on 2 May 2012.
  7. ^ "PyPI mirrors". Python Package Index. Python Software Foundation. Archived from the original on 3 May 2012. Retrieved 22 April 2012.
  8. ^ "PEP 427 -- The Wheel Binary Package Format 1.0". Python Software Foundation. 15 February 2013. Retrieved 28 October 2017.
  9. ^ "Browse : Python Package Index". Python Software Foundation. Retrieved 2 August 2016.
  10. ^ "Python 1.6.1". Python Software Foundation. Retrieved 24 April 2012.
  11. ^ "What's New in Python 2.0". Python Software Foundation. Retrieved 2 August 2016.
  12. ^ a b "PEP 301 -- Package Index and Metadata for Distutils". Python Software Foundation. 24 October 2002. Retrieved 3 June 2012.
  13. ^ "PEP 241 -- Metadata for Python Software Packages". Python Software Foundation. 19 October 2001. Retrieved 18 August 2016.
  14. ^ "Welcome to Warehouse's documentation!".
  15. ^ "Python Insider: New PyPI launched, legacy PyPI shutting down April 30". Python Software Foundation. 16 April 2018. Retrieved 1 June 2018.
  16. ^ "A new package index for Python". LWN.net. Retrieved 1 June 2018.
  17. ^ a b Durbin, Ee (24 May 2023). "PyPI was subpoenaed - The Python Package Index". blog.pypi.org.
  18. ^ Rudra, Sourav (25 May 2023). "The Python Software Foundation Complies with PyPI Subpoenas to Share Some User Data". It's FOSS News.