The Python Standard Library
The Python Standard Library
While The Python Language Reference describes the exact syntax and semantics of
the Python language, this library reference manual describes the standard library that
is distributed with Python. It also describes some of the optional components that are
commonly included in Python distributions.
The Python installers for the Windows platform usually include the entire standard
library and often also include many additional components. For Unix-like operating
systems Python is normally provided as a collection of packages, so it may be
necessary to use the packaging tools provided with the operating system to obtain
some or all of the optional components.
Introduction
o Notes on availability
Built-in Functions
Built-in Constants
o Constants added by the site module
Built-in Types
o Truth Value Testing
o Boolean Operations — and, or, not
o Comparisons
o Numeric Types — int, float, complex
o Iterator Types
o Sequence Types — list, tuple, range
o Text Sequence Type — str
o Binary Sequence Types — bytes, bytearray, memoryview
o Set Types — set, frozenset
o Mapping Types — dict
o Context Manager Types
o Other Built-in Types
o Special Attributes
Built-in Exceptions
o Base classes
o Concrete exceptions
o Warnings
o Exception hierarchy
Text Processing Services
o string — Common string operations
o re — Regular expression operations
o difflib — Helpers for computing deltas
o textwrap — Text wrapping and filling
o unicodedata — Unicode Database
o stringprep — Internet String Preparation
o readline — GNU readline interface
o rlcompleter — Completion function for GNU readline
Binary Data Services
o struct — Interpret bytes as packed binary data
o codecs — Codec registry and base classes
Data Types
o datetime — Basic date and time types
o calendar — General calendar-related functions
o collections — Container datatypes
o collections.abc — Abstract Base Classes for Containers
o heapq — Heap queue algorithm
o bisect — Array bisection algorithm
o array — Efficient arrays of numeric values
o weakref — Weak references
o types — Dynamic type creation and names for built-in types
o copy — Shallow and deep copy operations
o pprint — Data pretty printer
o reprlib — Alternate repr() implementation
o enum — Support for enumerations
Numeric and Mathematical Modules
o numbers — Numeric abstract base classes
o math — Mathematical functions
o cmath — Mathematical functions for complex numbers
o decimal — Decimal fixed point and floating point arithmetic
o fractions — Rational numbers
o random — Generate pseudo-random numbers
o statistics — Mathematical statistics functions
Functional Programming Modules
o itertools — Functions creating iterators for efficient looping
o functools — Higher-order functions and operations on callable
objects
o operator — Standard operators as functions
File and Directory Access
o pathlib — Object-oriented filesystem paths
o os.path — Common pathname manipulations
o fileinput — Iterate over lines from multiple input streams
o stat — Interpreting stat() results
o filecmp — File and Directory Comparisons
o tempfile — Generate temporary files and directories
o glob — Unix style pathname pattern expansion
o fnmatch — Unix filename pattern matching
o linecache — Random access to text lines
o shutil — High-level file operations
o macpath — Mac OS 9 path manipulation functions
Data Persistence
o pickle — Python object serialization
o copyreg — Register pickle support functions
o shelve — Python object persistence
o marshal — Internal Python object serialization
o dbm — Interfaces to Unix “databases”
o sqlite3 — DB-API 2.0 interface for SQLite databases
Data Compression and Archiving
o zlib — Compression compatible with gzip
o gzip — Support for gzip files
o bz2 — Support for bzip2 compression
o lzma — Compression using the LZMA algorithm
o zipfile — Work with ZIP archives
o tarfile — Read and write tar archive files
File Formats
o csv — CSV File Reading and Writing
o configparser — Configuration file parser
o netrc — netrc file processing
o xdrlib — Encode and decode XDR data
o plistlib — Generate and parse Mac OS X .plist files
Cryptographic Services
o hashlib — Secure hashes and message digests
o hmac — Keyed-Hashing for Message Authentication
o secrets — Generate secure random numbers for managing secrets
Generic Operating System Services
o os — Miscellaneous operating system interfaces
o io — Core tools for working with streams
o time — Time access and conversions
o argparse — Parser for command-line options, arguments and sub-
commands
o getopt — C-style parser for command line options
o logging — Logging facility for Python
o logging.config — Logging configuration
o logging.handlers — Logging handlers
o getpass — Portable password input
o curses — Terminal handling for character-cell displays
o curses.textpad — Text input widget for curses programs
o curses.ascii — Utilities for ASCII characters
o curses.panel — A panel stack extension for curses
o platform — Access to underlying platform’s identifying data
o errno — Standard errno system symbols
o ctypes — A foreign function library for Python
Concurrent Execution
o threading — Thread-based parallelism
o multiprocessing — Process-based parallelism
o The concurrent package
o concurrent.futures — Launching parallel tasks
o subprocess — Subprocess management
o sched — Event scheduler
o queue — A synchronized queue class
o _thread — Low-level threading API
o _dummy_thread — Drop-in replacement for the _thread module
o dummy_threading — Drop-in replacement for the threading module
contextvars — Context Variables
o Context Variables
o Manual Context Management
o asyncio support
Networking and Interprocess Communication
o asyncio — Asynchronous I/O
o socket — Low-level networking interface
o ssl — TLS/SSL wrapper for socket objects
o select — Waiting for I/O completion
o selectors — High-level I/O multiplexing
o asyncore — Asynchronous socket handler
o asynchat — Asynchronous socket command/response handler
o signal — Set handlers for asynchronous events
o mmap — Memory-mapped file support
Internet Data Handling
o email — An email and MIME handling package
o json — JSON encoder and decoder
o mailcap — Mailcap file handling
o mailbox — Manipulate mailboxes in various formats
o mimetypes — Map filenames to MIME types
o base64 — Base16, Base32, Base64, Base85 Data Encodings
o binhex — Encode and decode binhex4 files
o binascii — Convert between binary and ASCII
o quopri — Encode and decode MIME quoted-printable data
o uu — Encode and decode uuencode files
Structured Markup Processing Tools
o html — HyperText Markup Language support
o html.parser — Simple HTML and XHTML parser
o html.entities — Definitions of HTML general entities
o XML Processing Modules
o xml.etree.ElementTree — The ElementTree XML API
o xml.dom — The Document Object Model API
o xml.dom.minidom — Minimal DOM implementation
o xml.dom.pulldom — Support for building partial DOM trees
o xml.sax — Support for SAX2 parsers
o xml.sax.handler — Base classes for SAX handlers
o xml.sax.saxutils — SAX Utilities
o xml.sax.xmlreader — Interface for XML parsers
o xml.parsers.expat — Fast XML parsing using Expat
Internet Protocols and Support
o webbrowser — Convenient Web-browser controller
o cgi — Common Gateway Interface support
o cgitb — Traceback manager for CGI scripts
o wsgiref — WSGI Utilities and Reference Implementation
o urllib — URL handling modules
o urllib.request — Extensible library for opening URLs
o urllib.response — Response classes used by urllib
o urllib.parse — Parse URLs into components
o urllib.error — Exception classes raised by urllib.request
o urllib.robotparser — Parser for robots.txt
o http — HTTP modules
o http.client — HTTP protocol client
o ftplib — FTP protocol client
o poplib — POP3 protocol client
o imaplib — IMAP4 protocol client
o nntplib — NNTP protocol client
o smtplib — SMTP protocol client
o smtpd — SMTP Server
o telnetlib — Telnet client
o uuid — UUID objects according to RFC 4122
o socketserver — A framework for network servers
o http.server — HTTP servers
o http.cookies — HTTP state management
o http.cookiejar — Cookie handling for HTTP clients
o xmlrpc — XMLRPC server and client modules
o xmlrpc.client — XML-RPC client access
o xmlrpc.server — Basic XML-RPC servers
o ipaddress — IPv4/IPv6 manipulation library
Multimedia Services
o audioop — Manipulate raw audio data
o aifc — Read and write AIFF and AIFC files
o sunau — Read and write Sun AU files
o wave — Read and write WAV files
o chunk — Read IFF chunked data
o colorsys — Conversions between color systems
o imghdr — Determine the type of an image
o sndhdr — Determine type of sound file
o ossaudiodev — Access to OSS-compatible audio devices
Internationalization
o gettext — Multilingual internationalization services
o locale — Internationalization services
Program Frameworks
o turtle — Turtle graphics
o cmd — Support for line-oriented command interpreters
o shlex — Simple lexical analysis
Graphical User Interfaces with Tk
o tkinter — Python interface to Tcl/Tk
o tkinter.ttk — Tk themed widgets
o tkinter.tix — Extension widgets for Tk
o tkinter.scrolledtext — Scrolled Text Widget
o IDLE
o Other Graphical User Interface Packages
Development Tools
o typing — Support for type hints
o pydoc — Documentation generator and online help system
o doctest — Test interactive Python examples
o unittest — Unit testing framework
o unittest.mock — mock object library
o unittest.mock — getting started
o 2to3 - Automated Python 2 to 3 code translation
o test — Regression tests package for Python
o test.support — Utilities for the Python test suite
o test.support.script_helper — Utilities for the Python execution
tests
Debugging and Profiling
o bdb — Debugger framework
o faulthandler — Dump the Python traceback
o pdb — The Python Debugger
o The Python Profilers
o timeit — Measure execution time of small code snippets
o trace — Trace or track Python statement execution
o tracemalloc — Trace memory allocations
Software Packaging and Distribution
o distutils — Building and installing Python modules
o ensurepip — Bootstrapping the pip installer
o venv — Creation of virtual environments
o zipapp — Manage executable Python zip archives
Python Runtime Services
o sys — System-specific parameters and functions
o sysconfig — Provide access to Python’s configuration information
o builtins — Built-in objects
o __main__ — Top-level script environment
o warnings — Warning control
o dataclasses — Data Classes
o contextlib — Utilities for with-statement contexts
o abc — Abstract Base Classes
o atexit — Exit handlers
o traceback — Print or retrieve a stack traceback
o __future__ — Future statement definitions
o gc — Garbage Collector interface
o inspect — Inspect live objects
o site — Site-specific configuration hook
Custom Python Interpreters
o code — Interpreter base classes
o codeop — Compile Python code
Importing Modules
o zipimport — Import modules from Zip archives
o pkgutil — Package extension utility
o modulefinder — Find modules used by a script
o runpy — Locating and executing Python modules
o importlib — The implementation of import
Python Language Services
o parser — Access Python parse trees
o ast — Abstract Syntax Trees
o symtable — Access to the compiler’s symbol tables
o symbol — Constants used with Python parse trees
o token — Constants used with Python parse trees
o keyword — Testing for Python keywords
o tokenize — Tokenizer for Python source
o tabnanny — Detection of ambiguous indentation
o pyclbr — Python class browser support
o py_compile — Compile Python source files
o compileall — Byte-compile Python libraries
o dis — Disassembler for Python bytecode
o pickletools — Tools for pickle developers
Miscellaneous Services
o formatter — Generic output formatting
MS Windows Specific Services
o msilib — Read and write Microsoft Installer files
o msvcrt — Useful routines from the MS VC++ runtime
o winreg — Windows registry access
o winsound — Sound-playing interface for Windows
Unix Specific Services
o posix — The most common POSIX system calls
o pwd — The password database
o spwd — The shadow password database
o grp — The group database
o crypt — Function to check Unix passwords
o termios — POSIX style tty control
o tty — Terminal control functions
o pty — Pseudo-terminal utilities
o fcntl — The fcntl and ioctl system calls
o pipes — Interface to shell pipelines
o resource — Resource usage information
o nis — Interface to Sun’s NIS (Yellow Pages)
o syslog — Unix syslog library routines
Superseded Modules
o optparse — Parser for command line options
o imp — Access the import internals
Undocumented Modules
o Platform specific modules