bash Comparison Operators
Blogs20132013-03-19
bash Comparison Operators
Here is Bash comparison operators from http://tldp.org/LDP/abs/html/comparison-ops.html. I extracted for quick searching:
A binary comparison operator compares two variables or quantities. Note that integer and string comparison use a different set of operators.
integer comparison
-eq
is equal to
if [ β$aβ -eq β$bβ ]
-ne
is not equal to
if [ β$aβ -ne β$bβ ]
-gt
is greater than
if [ β$aβ -gt β$bβ ]
-ge
is greater than or equal to
if [ β$aβ -ge β$bβ ]
-lt
is less than
if [ β$aβ -lt β$bβ ]
-le
is less than or equal to
if [ β$aβ -le β$bβ ]
<
is less than (within double parentheses)
((β$aβ < β$bβ))
<=
is less than or equal to (within double parentheses)
((β$aβ <= β$bβ))
>
is greater than (within double parentheses)
((β$aβ > β$bβ))
>=
is greater than or equal to (within double parentheses)
((β$aβ >= β$bβ))
string comparison
=
is equal to
if [ β$aβ = β$bβ ]
![]() | Note the whitespace framing the =. if [ "$a"="$b" ] is not equivalent to the above. |
==
is equal to
if [ β$aβ == β$bβ ]
This is a synonym for =.
![]() | The == comparison operator behaves differently within a double-brackets test than within single brackets.
|
!=
is not equal to
if [ β$aβ != β$bβ ]
This operator uses pattern matching within a [[ β¦ ]] construct.
<
is less than, in ASCII alphabetical order
if [[ β$aβ < β$bβ ]]
if [ β$aβ < β$bβ ]
Note that the β<β needs to be escaped within a [ ] construct.
>
is greater than, in ASCII alphabetical order
if [[ β$aβ > β$bβ ]]
if [ β$aβ > β$bβ ]
Note that the β>β needs to be escaped within a [ ] construct.
See Example 27-11 for an application of this comparison operator.
-z
string is null, that is, has zero length
String='' # Zero-length ("null") string variable.
if [ -z "$String" ]
then
echo "$String is null."
else
echo "$String is NOT null."
fi # $String is null. |
-n
string is not null.
![]() | The -n test requires that the string be quoted within the test brackets. Using an unquoted string with ! -z, or even just the unquoted string alone within test brackets (see Example 7-6) normally works, however, this is an unsafe practice. Always quote a tested string. [1] |
Example 7-5. Arithmetic and string comparisons
#!/bin/bash a=4 b=5 # Here "a" and "b" can be treated either as integers or strings. # There is some blurring between the arithmetic and string comparisons, #+ since Bash variables are not strongly typed. # Bash permits integer operations and comparisons on variables #+ whose value consists of all-integer characters. # Caution advised, however. echo if [ "$a" -ne "$b" ] then echo "$a is not equal to $b" echo "(arithmetic comparison)" fi echo if [ "$a" != "$b" ] then echo "$a is not equal to $b." echo "(string comparison)" # "4" != "5" # ASCII 52 != ASCII 53 fi # In this particular instance, both "-ne" and "!=" work. echo exit 0 |
Example 7-6. Testing whether a string is null
#!/bin/bash # str-test.sh: Testing null strings and unquoted strings, #+ but not strings and sealing wax, not to mention cabbages and kings . . . # Using if [ ... ] # If a string has not been initialized, it has no defined value. # This state is called "null" (not the same as zero!). if [ -n $string1 ] # string1 has not been declared or initialized. then echo "String "string1" is not null." else echo "String "string1" is null." fi # Wrong result. # Shows $string1 as not null, although it was not initialized. echo # Let's try it again. if [ -n "$string1" ] # This time, $string1 is quoted. then echo "String "string1" is not null." else echo "String "string1" is null." fi # Quote strings within test brackets! echo if [ $string1 ] # This time, $string1 stands naked. then echo "String "string1" is not null." else echo "String "string1" is null." fi # This works fine. # The [ ... ] test operator alone detects whether the string is null. # However it is good practice to quote it (if [ "$string1" ]). # # As Stephane Chazelas points out, # if [ $string1 ] has one argument, "]" # if [ "$string1" ] has two arguments, the empty "$string1" and "]" |
Example 7-7. zmore
#!/bin/bash
# zmore
# View gzipped files with 'more' filter.
E_NOARGS=85
E_NOTFOUND=86
E_NOTGZIP=87
if [ $# -eq 0 ] # same effect as: if [ -z "$1" ]
# $1 can exist, but be empty: zmore "" arg2 arg3
then
echo "Usage: `basename $0` filename" >&2
# Error message to stderr.
exit $E_NOARGS
# Returns 85 as exit status of script (error code).
fi
filename=$1
if [ ! -f "$filename" ] # Quoting $filename allows for possible spaces.
then
echo "File $filename not found!" >&2 # Error message to stderr.
exit $E_NOTFOUND
fi
if [ ${filename##*.} != "gz" ]
# Using bracket in variable substitution.
then
echo "File $1 is not a gzipped file!"
exit $E_NOTGZIP
fi
zcat $1 | more
# Uses the 'more' filter.
# May substitute 'less' if desired.
exit $? # Script returns exit status of pipe.
# Actually "exit $?" is unnecessary, as the script will, in any case,
#+ return the exit status of the last command executed. |
compound comparison
-a
logical and
exp1 -a exp2 returns true if both exp1 and exp2 are true.
-o
logical or
exp1 -o exp2 returns true if either exp1 or exp2 is true.
These are similar to the Bash comparison operators && and ||, used within double brackets.
[[ condition1 && condition2 ]] |
The -o and -a operators work with the test command or occur within single test brackets.
if [ "$expr1" -a "$expr2" ] then echo "Both expr1 and expr2 are true." else echo "Either expr1 or expr2 is false." fi |
![]() | But, as rihad points out:
|


