getopts is a built-in Unix shell command for parsing command-line arguments. It is designed to process command line arguments that follow the POSIX Utility Syntax Guidelines.



getopts was first introduced in 1986 in the Bourne shell shipped with Unix SVR3.[1] Earlier versions of the Bourne shell did not have getopts; it is now available in shells including the Bourne shell, Korn shell, Almquist shell, Bash and Zsh.

Related programsEdit

getopts (Solaris enhanced)Edit

In spring 2004 (Solaris 10 beta development), the libc implementation for getopt() was enhanced to support long options. As a result, this new feature was also available in the built-in command getopts of the Bourne Shell.

getopt (original)Edit

getopts was developed as an improvement to the original getopt Unix program.

The original getopt program had fewer features than getopts. For example, it did not support whitespaces in arguments, and there was no ability to disable the output of error messages. It was an external command line program (unlike getopts which is a built-in shell command).

getopt (GNU enhanced)Edit

An alternative to getopts is the GNU enhanced version of getopt.

The GNU enhanced version of getopt supports the extra features of getopts plus more advanced features. It supports long option names (e.g. --help) and the options do not have to appear before all the operands (e.g. command operand1 operand2 -a operand3 -b is permitted by the GNU enhanced version of getopt but does not work with getopts).

The GNU enhanced version of getopt is an external command line program (unlike getopts which is a built-in shell command).


getopts getopts (Solaris enhanced) getopt (original) getopt (GNU enhanced)
Splitting options for easy parsing Yes Yes Yes Yes
Error messages can be suppressed Yes Yes - Yes
Whitespace allowed in arguments Yes Yes - Yes
Allows operands to be mixed with options - Yes - Yes
Long options support - Yes - Yes

See alsoEdit


  1. ^ Mascheck, Sven. "The Traditional Bourne Shell Family". Retrieved 2010-12-01.

External linksEdit