cpython/Doc/library/__main__.rst

26 lines
904 B
ReStructuredText
Raw Normal View History

2007-08-15 11:28:22 -03:00
:mod:`__main__` --- Top-level script environment
================================================
.. module:: __main__
:synopsis: The environment where the top-level script is run.
--------------
2014-04-14 19:53:51 -03:00
``'__main__'`` is the name of the scope in which top-level code executes.
A module's __name__ is set equal to ``'__main__'`` when read from
standard input, a script, or from an interactive prompt.
2007-08-15 11:28:22 -03:00
A module can discover whether or not it is running in the main scope by
2014-04-14 19:53:51 -03:00
checking its own ``__name__``, which allows a common idiom for conditionally
executing code in a module when it is run as a script or with ``python
-m`` but not when it is imported::
2007-08-15 11:28:22 -03:00
if __name__ == "__main__":
# execute only if run as a script
2007-08-15 11:28:22 -03:00
main()
For a package, the same effect can be achieved by including a
2014-04-14 19:53:51 -03:00
``__main__.py`` module, the contents of which will be executed when the
module is run with ``-m``.