Python modules, fundamental units of organization, come in two forms: code modules and package modules. Code modules consist of executable Python code, while package modules encompass directories containing other modules.
Python assigns unique identifiers to modules, known as both modulenames and filenames. Typically, modules are identified by modulename in Python code and filename on the command line. Python seamlessly translates modulenames to filenames using the sys.path variable.
Introduced in Python 2.4.1, the -m switch originally enabled the execution of modules from the command line based on their modulenames. This provided an alternative to specifying filenames. In its initial iteration, -m only supported top-level modulenames.
PEP 338 extended -m to handle more complex modulename representations, allowing execution of nested modules such as http.server. Furthermore, it mandated the evaluation of all parent package __init__.py files.
The final key advancement came with PEP 366, granting -m the ability to support not only absolute but also explicit relative imports. This was achieved by setting the package variable to the parent module of the given modulename.
Despite its capabilities, -m is limited in that it can only execute modules written in Python (.py files). C compiled code modules are not supported.
Module Execution via Import Statement:
Module Execution via Command Line with Filename:
Module Execution via Command Line with Modulename (-m):
The -m switch serves as a powerful tool for executing Python modules from the command line. Its ability to convert modulenames to filenames, execute local packages, and support relative imports provides a convenient and versatile means of managing Python code. Despite its limitation to executing Python-based modules, -m remains an invaluable asset for Python developers.
The above is the detailed content of What is the purpose of Python\'s `-m` switch?. For more information, please follow other related articles on the PHP Chinese website!