Staging
v0.8.1
Revision 27ea3c782f0cc67805a3486336ce71f3ae08ba8a authored by Mariatta on 01 August 2017, 04:34:47 UTC, committed by GitHub on 01 August 2017, 04:34:47 UTC
(cherry picked from commit e1e60bd95c376f9b18cbaf9481364281c6cc1bc7)
1 parent f6306e7
Raw File
__main__.rst

:mod:`__main__` --- Top-level script environment
================================================

.. module:: __main__
   :synopsis: The environment where the top-level script is run.

--------------

``'__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.

A module can discover whether or not it is running in the main scope by
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::

   if __name__ == "__main__":
       # execute only if run as a script
       main()

For a package, the same effect can be achieved by including a
``__main__.py`` module, the contents of which will be executed when the
module is run with ``-m``.
back to top