Module 48 expr

Previous Table of Contents Next


Module 48
expr

DESCRIPTION

The external expr command evaluates and compares expressions. An expression is composed of operands and operators. The operands are strings or integers; the operators are special characters used to inform expr how to interpret and compare the operands.

Operands and operators must be separated by blanks. Characters having special meaning to the shell must be escaped using the backslash (\) or quoted by single or double quotes. The parenthesis used for regular expression must always be preceded by backslashes. Strings containing blanks must be quoted to be considered one argument. You may precede integers with a minus sign ( “) to represent a negative number.

The expr command can be used to perform many functions but it should be used as a last resort command. The ksh and csh shell provide much faster and usually easier ways of performing calculations and comparisons.

COMMAND FORMAT

Following is the general format of the expr command.

 expr arg1 operator arg2 ... 

Multiple operators may be specified on the command line.

Arguments

The following list describes the arguments that may be passed to the expr command. The list is in decreasing precedence of the operators.

String Matching Operators

arg1 : arg2 Matching operator. Compares the characters in arg1 with the characters in arg2 . Returns the number of characters in arg1 matched by characters in arg2 . Arg1 should be a string and arg2 should be a regular expression recognized by the ed command, with the exception of the ^ character, because all expressions start at the beginning of arg2 . The following examples illustrate the use of the matching operator:
$ expr string : str # First 3 characters match
3
$ expr string : ing # Last 3 match but comparison
# must start at beginning of arg1
$ expr string : strg # Arg2 must match arg1 in its
# entirety
$ expr string : .* # .* is a regular expression
6 # that matches any number of
# any characters
$ expr string : .*i # .*i matches any set of
4 # characters ending with i
You may find times when you need to return the matching portion of the string instead of the number of matching characters. You can use the \(...\) notation to perform this function. For example:
$ expr string : \(.*\) # Returns all chars in arg1
string
$ expr string : ..\(..\) # Skips first 2 chars of
ri # arg1, returns next 2
$ expr string : \(...\) # Returns first 3 chars of
str # arg1
$ expr string : .*\(...\) # Returns last 3 chars of
ing # arg1
$ expr string : ..\(.*\).. Returns center of arg1
ri # first and last 2 chars
# removed
$ expr string : \(stx\) # Returns nothing
$ expr string : st\(.*\) # Return all of arg1 after
ring # skipping st

Integer Arithmetic Operators      The following operators perform integer arithmetic. The returned value of a division operation is truncated to the largest integer. The multiplication, division, and modulus functions have equal precedence. The addition and subtraction operators have equal precedence but are lower in precedence than the previous three arithmetic operators. The * for multiplication must be escaped with a \ (backslash) or quoted to avoid shell interpretation.

arg1 \* arg2 Displays the value of arg1 multiplied by arg2 . For example,
$ expr 80 \* 24
1920
arg1 / arg2 Displays the integer value of arg1 divided by arg2. For example,
$ expr 15 / 4
3
Notice the result of 15 / 4 is 3.75 but the value is truncated to the next lower number.
arg1 % arg2 Displays the remainder (modulus) of arg1 divided by arg2 . For instance,
$ expr 15 % 4
3
1 arg1 + arg2 Display the value of arg1 added to arg2 . For example,
$ NUM=0
$ expr $NUM + 1
1
arg1 arg2 Display the value of arg2 subtracted from arg1 . For example,
$ expr $NUM - 1


Previous Table of Contents Next

Copyright Wordware Publishing, Inc.


Illustrated UNIX System V
Illustrated Unix System V/Bsd
ISBN: 1556221878
EAN: 2147483647
Year: N/A
Pages: 144
Authors: Robert Felps

flylib.com © 2008-2017.
If you may any questions please contact us: flylib@qtcs.net