I have following script in Python 3.2.3:
try:
file = open('file.txt', 'r')
except IOError:
print('There was an error opening the file!')
sys.exit()
#more code that is relevant only if the file exists
How do I exit gracefully, if the file doesn't exist (or there is simply an error opening it)?
I can use exit()
, but that opens a dialog panel asking if I want to kill the application.
I can use sys.exit()
, but that raises a SystemExit exception which doesn't looks great in output. I get
Traceback (most recent call last):
File "file", line 19, in <module>
sys.exit() SystemExit
I can use os.exit()
, but that kills the Python on C level, without any cleanups I might be performing.
I can use a boolean variable and wrap all subsequent code in if... but that is ugly, and this is not the only check I am performing. So I would have like six nested ifs...
I just want to print the 'There was an error...' and exit. I am working in IDLE.
This is a very graceful way to do it. The SystemExit traceback won't be printed outside of IDLE. Optionally you can use
sys.exit(1)
to indicate to the shell that the script terminated with an error.Alternatively you could do this in your "main" function and use
return
to terminate the application:Here the main execution code of the application is encapsulated in a single function called "main", then executed only if the script is executed directly by the Python interpreter, or in other words, if the script it not being imported by another script. (The
__name__
variable is set to "__main__" if the script is being executed directly from the command line. Otherwise it will be set to the name of the module.)This has the advantage of gathering all script execution logic into a single function, making your script cleaner, and enables you to cleanly exit your script using the
return
statement, just like in most compiled languages.Using sys.exit() is fine. If you're that concerned with output, you can always add an extra try/except block within your error handling section to catch the SystemExit and stop it from being directed to console output.