Difference between exit(0) and exit(1) in Python
Asked Answered
O

5

241

What's the difference between exit(0) and exit(1) in Python?

I tried looking around but didn't find a specific question on these lines. If it's already been answered, a link would be sufficient.

Otolaryngology answered 24/2, 2012 at 5:49 Comment(6)
Here's a link to exit() in the docs, which took me forever to find.Marthamarthe
keep in mind: The site module (which is imported automatically during startup, except if the -S command-line option is given) adds several constants to the built-in namespace. They are useful for the interactive interpreter shell and should not be used in programs, instead, use sys.exit()Concision
Just realised there is exit(0) which is discussed in this question and also one with an underscore _exit(0), the difference is explained hereCalibrate
The nice thing about these codes is that they can be used directly in an if statement in a bash wrapper, so further action can be taken whether or not the Python program succeeds or whether it raised a non-zero status.Scrawly
weird, if 0 is False and 1 is True in Python, you'd think the numbers would mean the oppositePostrider
@MonicaHeddneck It's for historical reasons, and because there's only really one way to say "Everything went fine!", while there might be 255 or more ways to say how things went wrong. Thus "0" is the universal "Success" code, and everything else is "Here's a short code you can look up in the manual for this program to learn what went wrong".Congregational
I
356

0 and 1 are the exit codes.

exit(0) means a clean exit without any errors / problems

exit(1) means there was some issue / error / problem and that is why the program is exiting.

This is not Python specific and is pretty common. A non-zero exit code is treated as an abnormal exit, and at times, the error code indicates what the problem was. A zero error code means a successful exit.

This is useful for other programs, shell, caller etc. to know what happened with your program and proceed accordingly.

Inhibit answered 24/2, 2012 at 5:50 Comment(7)
And what about exit(-1) ?Cannabis
@Faizan: The exit code is an 8-bit value on Unix. If you invoke exit(-1), the value is equivalent to exit(255) - the least significant 8 bits are relayed to the calling program (shell or whatever).Fructuous
Note that according to the docs, exit() is added by the site module, and should not be used by programs. Instead, use sys.exit(), or even raise SystemExit, if you don't want to import another module.Joli
Because of exit codes from Unix/Linux, I was thinking 0 is True and 1 is False value in the Python conditions.Wangle
any nonzero value is considered “abnormal termination” by shells and the like. Most systems require it to be in the range 0–127, and produce undefined results otherwise. Some systems have a convention for assigning specific meanings to specific exit codes, but these are generally underdeveloped; Unix programs ... use 2 for command line syntax errors and 1 for all other errors. If another type of object is passed, None is equivalent to passing zero, and any other object is printed to stderr and results in an exit code of 1. sys module docsValdavaldas
i like to think of it as 0 for 0 errors during executionRadiography
The one thing I couldn't find out, that if there is a problem with the python code (syntax, unhandled exception), the interpreter always returns with 1 or there ore some other error statuses? I know I can use different numbers for different reasons e.g. sys.exit(42) for question.txt not found, sys.exit(3) for Earth (and so the Internet connection) was destroyed by the Vogons...Quidnunc
R
23

This determines the exit status of the program when it finishes running (generally, 0 for success and 1 for error).

It is not unique to Python, and the exact effect depends on your operating system and how the program is called (though 99% of the time, if you're just running Python scripts, it doesn't matter).

Radke answered 24/2, 2012 at 5:51 Comment(0)
F
17

The standard convention for all C programs, including Python, is for exit(0) to indicate success, and exit(1) or any other non-zero value (in the range 1..255) to indicate failure. Any value outside the range 0..255 is treated modulo 256 (the exit status is stored in an 8-bit value). Sometimes, that will be treated as signed (so you might see -128, -127, etc) but more usually it is treated as unsigned.

This status is available to the code that invoked Python. This convention applies across platforms, though the meaning of non-zero exit status can vary on different platforms.

Fructuous answered 24/2, 2012 at 5:52 Comment(0)
I
11

exit(0): This causes the program to exit with a successful termination.

exit(1): This causes the program to exit with a system-specific meaning.

On many systems, exit(1) signals some sort of failure, however there is no guarantee.

As I recall, the C standard only recognizes three standard exit values:

  • EXIT_SUCCESS -- successful termination
  • EXIT_FAILURE -- unsuccessful termination
  • 0 -- same as EXIT_SUCCESS
Immediately answered 14/11, 2015 at 6:13 Comment(0)
U
8

The number you pass to the exit() function is simply your program's return code, which is given to the operating system. From your program's point of view, there is no difference: execution will end in both cases, and the value supplied to the function will be given to the OS. But some tools and scripts take into account the program's exit code. Most tools return 0 when they succeed and nonzero to indicate an error.

So, if your program will be run from a script, an automated tool or from some other software that takes into account the return code (such as an IDE), you must be careful on what you return.

When in doubt, just return 0 to indicate everything is OK.

Unification answered 24/2, 2012 at 5:57 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.