As pointed out by @bobince:
You will also be __main__
if you are a module invoked by python -m somemodule
Let's suppose you have a Python file bar.py
and an empty __init__.py
, both inside a folder called foo
:
$ tree
.
└── foo
├── __init__.py
└── bar.py
$ cat foo/__init__.py
The Python code blocks below are the content of foo/bar.py
.
Using __name__
(not working)
print('Code executed as a %s' % 'script' if __name__ == '__main__' else 'module')
This will produce:
$ python foo/bar.py
Code executed as a script
$ python -m foo.bar
Code executed as a script
import sys
mod_name = vars(sys.modules[__name__])['__package__']
print('Code executed as a ' + ('module named %s' % mod_name if mod_name else 'script'))
This will produce:
$ python foo/bar.py
Code executed as a module named foo
$ python -m foo.bar
Code executed as a script
Solution 2: Using a try-except block on module import
import sys
try:
import foo
print('Code executed as a module')
except ImportError:
print('Code executed as a script')
# Code will fail here, but you can still print a comprehensive error message before exiting:
print('Usage: python -m foo.bar')
sys.exit()
This will produce:
$ python foo/bar.py
Code executed as a module
$ python -m foo.bar
Code executed as a script
Usage: python -m foo.bar