Contents | Previous (3.4 Modules) | Next (3.6 Design Discussion)
This section introduces the concept of a main program or main module.
In many programming languages, there is a concept of a main function or method.
// c / c++
int main(int argc, char *argv[]) {
...
}
// java
class myprog {
public static void main(String args[]) {
...
}
}
This is the first function that executes when an application is launched.
Python has no main function or method. Instead, there is a main module. The main module is the source file that runs first.
bash % python3 prog.py
...
Whatever file you give to the interpreter at startup becomes main. It doesn't matter the name.
It is standard practice for modules that run as a main script to use this convention:
# prog.py
...
if __name__ == '__main__':
# Running as the main program ...
statements
...
Statements enclosed inside the if
statement become the main program.
Any Python file can either run as main or as a library import:
bash % python3 prog.py # Running as main
import prog # Running as library import
In both cases, __name__
is the name of the module. However, it will only be set to __main__
if
running as main.
Usually, you don't want statements that are part of the main program
to execute on a library import. So, it's common to have an if-
check
in code that might be used either way.
if __name__ == '__main__':
# Does not execute if loaded with import ...
Here is a common program template for writing a Python program:
# prog.py
# Import statements (libraries)
import modules
# Functions
def spam():
...
def blah():
...
# Main function
def main():
...
if __name__ == '__main__':
main()
Python is often used for command-line tools
bash % python3 report.py portfolio.csv prices.csv
It means that the scripts are executed from the shell / terminal. Common use cases are for automation, background tasks, etc.
The command line is a list of text strings.
bash % python3 report.py portfolio.csv prices.csv
This list of text strings is found in sys.argv
.
# In the previous bash command
sys.argv # ['report.py, 'portfolio.csv', 'prices.csv']
Here is a simple example of processing the arguments:
import sys
if len(sys.argv) != 3:
raise SystemExit(f'Usage: {sys.argv[0]} ' 'portfile pricefile')
portfile = sys.argv[1]
pricefile = sys.argv[2]
...
Standard Input / Output (or stdio) are files that work the same as normal files.
sys.stdout
sys.stderr
sys.stdin
By default, print is directed to sys.stdout
. Input is read from
sys.stdin
. Tracebacks and errors are directed to sys.stderr
.
Be aware that stdio could be connected to terminals, files, pipes, etc.
bash % python3 prog.py > results.txt
# or
bash % cmd1 | python3 prog.py | cmd2
Environment variables are set in the shell.
bash % setenv NAME dave
bash % setenv RSH ssh
bash % python3 prog.py
os.environ
is a dictionary that contains these values.
import os
name = os.environ['NAME'] # 'dave'
Changes are reflected in any subprocesses later launched by the program.
Program exit is handled through exceptions.
raise SystemExit
raise SystemExit(exitcode)
raise SystemExit('Informative message')
An alternative.
import sys
sys.exit(exitcode)
A non-zero exit code indicates an error.
On Unix, the #!
line can launch a script as Python.
Add the following to the first line of your script file.
#!/usr/bin/env python3
# prog.py
...
It requires the executable permission.
bash % chmod +x prog.py
# Then you can execute
bash % prog.py
... output ...
Note: The Python Launcher on Windows also looks for the #!
line to indicate language version.
Finally, here is a common code template for Python programs that run as command-line scripts:
#!/usr/bin/env python3
# prog.py
# Import statements (libraries)
import modules
# Functions
def spam():
...
def blah():
...
# Main function
def main(argv):
# Parse command line args, environment, etc.
...
if __name__ == '__main__':
import sys
main(sys.argv)
In the file report.py
add a main()
function that accepts a list of
command line options and produces the same output as before. You
should be able to run it interatively like this:
>>> import report
>>> report.main(['report.py', 'Data/portfolio.csv', 'Data/prices.csv'])
Name Shares Price Change
---------- ---------- ---------- ----------
AA 100 39.91 7.71
IBM 50 106.11 15.01
CAT 150 78.58 -4.86
MSFT 200 30.47 -20.76
GE 95 37.38 -2.99
MSFT 50 30.47 -34.63
IBM 100 106.11 35.67
>>>
Modify the pcost.py
file so that it has a similar main()
function:
>>> import pcost
>>> pcost.main(['pcost.py', 'Data/portfolio.csv'])
Total cost: 44671.15
>>>
Modify the report.py
and pcost.py
programs so that they can
execute as a script on the command line:
bash $ python3 report.py Data/portfolio.csv Data/prices.csv
Name Shares Price Change
---------- ---------- ---------- ----------
AA 100 39.91 7.71
IBM 50 106.11 15.01
CAT 150 78.58 -4.86
MSFT 200 30.47 -20.76
GE 95 37.38 -2.99
MSFT 50 30.47 -34.63
IBM 100 106.11 35.67
bash $ python3 pcost.py Data/portfolio.csv
Total cost: 44671.15
Contents | Previous (3.4 Modules) | Next (3.6 Design Discussion)