d6b3e4b6cb
fix order of OFS and ORS in variable list
550 lines
12 KiB
Groff
550 lines
12 KiB
Groff
.\" $NetBSD: awk.1,v 1.3 2001/02/04 20:47:50 jdolecek Exp $
|
|
.\"
|
|
.\" Copyright (C) Lucent Technologies 1997
|
|
.\" All Rights Reserved
|
|
.\"
|
|
.\" Permission to use, copy, modify, and distribute this software and
|
|
.\" its documentation for any purpose and without fee is hereby
|
|
.\" granted, provided that the above copyright notice appear in all
|
|
.\" copies and that both that the copyright notice and this
|
|
.\" permission notice and warranty disclaimer appear in supporting
|
|
.\" documentation, and that the name Lucent Technologies or any of
|
|
.\" its entities not be used in advertising or publicity pertaining
|
|
.\" to distribution of the software without specific, written prior
|
|
.\" permission.
|
|
.\"
|
|
.\" LUCENT DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
|
|
.\" INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS.
|
|
.\" IN NO EVENT SHALL LUCENT OR ANY OF ITS ENTITIES BE LIABLE FOR ANY
|
|
.\" SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
.\" WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER
|
|
.\" IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
|
|
.\" ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF
|
|
.\" THIS SOFTWARE.
|
|
.\"
|
|
.Dd January 3, 1998
|
|
.Dt AWK 1
|
|
.Os
|
|
.Sh NAME
|
|
.Nm awk
|
|
.Nd pattern-directed scanning and processing language
|
|
.Sh SYNOPSIS
|
|
.Nm
|
|
.Op Fl F Ar fs
|
|
.Op Fl v Ar var=value
|
|
.Op Ar prog | Fl f Ar progname
|
|
.Ar
|
|
.Sh DESCRIPTION
|
|
.Nm
|
|
scans each input
|
|
.Ar file
|
|
for lines that match any of a set of patterns specified literally in
|
|
.Ar prog
|
|
or in one or more files
|
|
specified as
|
|
.Fl f Ar progfile .
|
|
With each pattern
|
|
there can be an associated action that will be performed
|
|
when a line of a
|
|
.I file
|
|
matches the pattern.
|
|
Each line is matched against the
|
|
pattern portion of every pattern-action statement;
|
|
the associated action is performed for each matched pattern.
|
|
The file name
|
|
.Ar -
|
|
means the standard input.
|
|
Any
|
|
.Ar file
|
|
of the form
|
|
.Ar var=value
|
|
is treated as an assignment, not a filename,
|
|
and is executed at the time it would have been opened if it were a filename.
|
|
The option
|
|
.Fl v
|
|
followed by
|
|
.Ar var=value
|
|
is an assignment to be done before
|
|
.Ar prog
|
|
is executed;
|
|
any number of
|
|
.Fl v
|
|
options may be present.
|
|
The
|
|
.Fl F Ar fs
|
|
option defines the input field separator to be the regular expression
|
|
.Ar fs.
|
|
.Pp
|
|
An input line is normally made up of fields separated by white space,
|
|
or by regular expression
|
|
.Va FS .
|
|
The fields are denoted
|
|
.Va $1 ,
|
|
.Va $2 ,
|
|
\&..., while
|
|
.Va $0
|
|
refers to the entire line.
|
|
If
|
|
.Va FS
|
|
is null, the input line is split into one field per character.
|
|
.Pp
|
|
A pattern-action statement has the form
|
|
.sp
|
|
.Dl pattern \&{ action \&}
|
|
.sp
|
|
A missing \&{ action \&}
|
|
means print the line;
|
|
a missing pattern always matches.
|
|
Pattern-action statements are separated by newlines or semicolons.
|
|
.Pp
|
|
An action is a sequence of statements.
|
|
Statements are terminated by
|
|
semicolons, newlines or right braces.
|
|
An empty
|
|
.Ar expression-list
|
|
stands for
|
|
.Va $0 .
|
|
String constants are quoted \&\f(CW"\ "\fR,
|
|
with the usual C escapes recognized within.
|
|
Expressions take on string or numeric values as appropriate,
|
|
and are built using the operators
|
|
.Ic + \- * / % ^
|
|
(exponentiation), and concatenation (indicated by white space).
|
|
The operators
|
|
.Ic ! ++ \-\- += \-= *= /= %= ^= > >= < <= == != ?:
|
|
are also available in expressions.
|
|
Variables may be scalars, array elements
|
|
(denoted
|
|
.Va x[i] )
|
|
or fields.
|
|
Variables are initialized to the null string.
|
|
Array subscripts may be any string,
|
|
not necessarily numeric;
|
|
this allows for a form of associative memory.
|
|
Multiple subscripts such as
|
|
.Va [i,j,k]
|
|
are permitted; the constituents are concatenated,
|
|
separated by the value of
|
|
.Va SUBSEP .
|
|
.Pp
|
|
.Ss Control Statements
|
|
The control statements are as follows:
|
|
.Pp
|
|
.Bl -hang -offset indent -width "" -compact
|
|
.It Xo
|
|
.Ic if \&( Ar expression Ic \&) Ar statement
|
|
.Bq Ic else Ar statement
|
|
.Xc
|
|
.It Ic while( Ar expression Ic \&) Ar statement
|
|
.It Xo
|
|
.Ic for( Ar expression Ic \&; Ar expression Ic \&;
|
|
.Ar expression Ic \&)
|
|
.Ar statement
|
|
.Xc
|
|
.It Xo
|
|
.Ic for( Va var Ic in Ar array
|
|
.Ic \&)
|
|
.Ar statement
|
|
.Xc
|
|
.It Xo
|
|
.Ic do Ar statement
|
|
.Ic while( Ar expression Ic \&)
|
|
.Xc
|
|
.It Ic break
|
|
.It Ic continue
|
|
.It Ic delete Va array Bq Ar expression
|
|
.It Ic delete Va array
|
|
.It Ic exit Bq Ar expression
|
|
.Ar expression
|
|
.It Ic return Bq Ar expression
|
|
.It Ic { Ar [ statement ... ] Ic }
|
|
.El
|
|
.Pp
|
|
.Ss I/O Statements
|
|
The input/ouput statements are as follows:
|
|
.Pp
|
|
.Bl -tag -width indent
|
|
.It Fn close expr
|
|
Closes the file or pipe
|
|
.Ar expr .
|
|
.It Fn fflush expr
|
|
Flushes any buffered output for the file or pipe
|
|
.Ar expr .
|
|
.It Ic getline Bq Va var
|
|
Set
|
|
.Va var
|
|
(or
|
|
.Va $0 if
|
|
.Va var
|
|
is not specified)
|
|
to the next input record from the current input file.
|
|
.Ic getline
|
|
returns 1 for a successful input,
|
|
0 for end of file, and \-1 for an error.
|
|
.It Xo
|
|
.Ic getline
|
|
.Bq Va var
|
|
.Ic <
|
|
.Ar file
|
|
.Xc
|
|
Set
|
|
.Va var
|
|
(or
|
|
.Va $0 if
|
|
.Va var
|
|
is not specified)
|
|
to the next input record from the specified file
|
|
.Ar file .
|
|
.It Ar expr Ic \&| getline
|
|
Pipes the output of
|
|
.Ar expr
|
|
into
|
|
.Ic getline ;
|
|
each call of
|
|
.Ic getline
|
|
returns the next line of output from
|
|
.Ar expr .
|
|
.It Ic next
|
|
Skip remaining patterns on this input line.
|
|
.It Ic nextfile
|
|
Skip rest of this file, open next, start at top.
|
|
.It Xo
|
|
.Ic print
|
|
.Bq Ar expr-list
|
|
.Bq Ic > Ar file
|
|
.Xc
|
|
The
|
|
.Ic print
|
|
statement prints its arguments on the standard output (or to a file
|
|
if
|
|
.Ic > file
|
|
or to a pipe if
|
|
.Ic | Ar expr
|
|
is present),
|
|
separated by the current output field separator
|
|
.Va OFS ,
|
|
and terminated by the
|
|
output record separator
|
|
.Va ORS .
|
|
Both
|
|
.Ar file
|
|
and
|
|
.Ar expr
|
|
may be literal names or parenthesized expressions; identical string values in
|
|
different statements denote the same open file.
|
|
.It Xo
|
|
.Ic printf
|
|
.Ar format
|
|
.Bq Ic , Ar expr-list
|
|
.Bq Ic > Ar file
|
|
.Xc
|
|
Format and print its expression list according to
|
|
.Ar format .
|
|
See
|
|
.Xr printf 3
|
|
for list of supported formats and their meaning.
|
|
.El
|
|
.Ss Mathematical and Numeric Functions
|
|
AWK has the following mathematical and numerical functions built-in:
|
|
.Pp
|
|
.Bl -tag -width indent
|
|
.It Fn atan2 x y
|
|
Returns the arctangent of
|
|
.Ar x Ic / Ar y
|
|
in radians. See also
|
|
.Xr atan2 3 .
|
|
.It Fn cos expr
|
|
Computes the cosine of
|
|
.Ar expr ,
|
|
measured in radians. See also
|
|
.Xr cos 3 .
|
|
.It Fn exp expr
|
|
Computes the exponential value of the given argument
|
|
.Ar expr .
|
|
See also
|
|
.Xr exp 3 .
|
|
.It Fn int expr
|
|
Truncates
|
|
.Ar expr
|
|
to integer.
|
|
.It Fn log expr
|
|
Computes the value of the natural logarithm of argument
|
|
.Ar expr .
|
|
See also
|
|
.Xr log 3 .
|
|
.It Fn rand
|
|
Returns random number between 0 and 1.
|
|
.It Fn sin expr
|
|
Computes the sine of
|
|
.Ar expr ,
|
|
measured in radians. See also
|
|
.Xr sin 3 .
|
|
.It Fn sqrt expr
|
|
Computes the non-negative square root of
|
|
.Ar expr .
|
|
See also
|
|
.Xr sqrt 3 .
|
|
.It Fn srand [expr]
|
|
Sets seed for random number generator (
|
|
.Fn rand )
|
|
and returns the previous seed.
|
|
.El
|
|
.Pp
|
|
.Ss String Functions
|
|
AWK has the following string functions built-in:
|
|
.Pp
|
|
.Bl -tag -width indent
|
|
.It Fn gsub
|
|
same as
|
|
.Fn sub
|
|
except that all occurrences of the regular expression
|
|
are replaced;
|
|
.Fn sub
|
|
and
|
|
.Fn gsub
|
|
return the number of replacements.
|
|
.It Fn index s t
|
|
the position in
|
|
.Ar s
|
|
where the string
|
|
.Ar t
|
|
occurs, or 0 if it does not.
|
|
.It Fn length "[string]"
|
|
the length of its argument
|
|
taken as a string,
|
|
or of
|
|
.Va $0
|
|
if no argument.
|
|
.It Fn match s r
|
|
the position in
|
|
.Ar s
|
|
where the regular expression
|
|
.Ar r
|
|
occurs, or 0 if it does not.
|
|
The variables
|
|
.Va RSTART
|
|
and
|
|
.Va RLENGTH
|
|
are set to the position and length of the matched string.
|
|
.It Fn split s a "[fs]"
|
|
splits the string
|
|
.Ar s
|
|
into array elements
|
|
.Va a[1] ,
|
|
.Va a[2] ,
|
|
\&...,
|
|
.Va a[n] ,
|
|
and returns
|
|
.Va n .
|
|
The separation is done with the regular expression
|
|
.Ar fs
|
|
or with the field separator
|
|
.Va FS
|
|
if
|
|
.Ar fs
|
|
is not given.
|
|
An empty string as field separator splits the string
|
|
into one array element per character.
|
|
.It Fn sprintf fmt expr "..."
|
|
Returns the string resulting from formatting
|
|
.Ar expr
|
|
according to the
|
|
.Xr printf 3
|
|
format
|
|
.Ar fmt .
|
|
.It Fn sub r t "[s]"
|
|
substitutes
|
|
.Ar t
|
|
for the first occurrence of the regular expression
|
|
.Ar r
|
|
in the string
|
|
.Ar s .
|
|
If
|
|
.Ar s
|
|
is not given,
|
|
.Va $0
|
|
is used.
|
|
.It Fn substr s m [n]
|
|
Returns the at most
|
|
.Ar n -character
|
|
substring of
|
|
.Ar s
|
|
starting at position
|
|
.Ar m ,
|
|
counted from 1. If
|
|
.Ar n
|
|
is omitted, the rest of
|
|
.Ar s
|
|
is returned.
|
|
.It Fn tolower str
|
|
returns a copy of
|
|
.Ar str
|
|
with all upper-case characters translated to their
|
|
corresponding lower-case equivalents.
|
|
.It Fn toupper str
|
|
returns a copy of
|
|
.Ar str
|
|
with all lower-case characters translated to their
|
|
corresponding upper-case equivalents.
|
|
.El
|
|
.Pp
|
|
.Ss Other built-in functions
|
|
.Pp
|
|
.Bl -tag -width indent
|
|
.It Fn system cmd
|
|
executes
|
|
.Ar cmd
|
|
and returns its exit status
|
|
.El
|
|
.Ss Patterns
|
|
Patterns are arbitrary Boolean combinations
|
|
(with
|
|
.Ic "! || &&" )
|
|
of regular expressions and
|
|
relational expressions.
|
|
Regular expressions are as in
|
|
.Xr egrep 1 .
|
|
Isolated regular expressions
|
|
in a pattern apply to the entire line.
|
|
Regular expressions may also occur in
|
|
relational expressions, using the operators
|
|
.Ic ~
|
|
and
|
|
.Ic !~ .
|
|
.Ic / re /
|
|
is a constant regular expression;
|
|
any string (constant or variable) may be used
|
|
as a regular expression, except in the position of an isolated regular expression
|
|
in a pattern.
|
|
.Pp
|
|
A pattern may consist of two patterns separated by a comma;
|
|
in this case, the action is performed for all lines
|
|
from an occurrence of the first pattern
|
|
though an occurrence of the second.
|
|
.Pp
|
|
A relational expression is one of the following:
|
|
.Bl -tag -offset indent -width indent -compact
|
|
.It Ar expression matchop regular-expression
|
|
.It Ar expression relop expression
|
|
.It Ar expression Ic in Ar array-name
|
|
.It ( Ar expr , expr,\&... Ic ") in" Ar array-name
|
|
.El
|
|
.Pp
|
|
where a
|
|
.Ar relop
|
|
is any of the six relational operators in C,
|
|
and a
|
|
.Ar matchop
|
|
is either
|
|
.Ic ~
|
|
(matches)
|
|
or
|
|
.Ic !~
|
|
(does not match).
|
|
A conditional is an arithmetic expression,
|
|
a relational expression,
|
|
or a Boolean combination
|
|
of these.
|
|
.Pp
|
|
The special patterns
|
|
.Ic BEGIN
|
|
and
|
|
.Ic END
|
|
may be used to capture control before the first input line is read
|
|
and after the last.
|
|
.Ic BEGIN
|
|
and
|
|
.Ic END
|
|
do not combine with other patterns.
|
|
.Ss Built-in Variables
|
|
Variable names with special meanings:
|
|
.Bl -hang -width FILENAMES
|
|
.It Va ARGC
|
|
argument count, assignable
|
|
.It Va ARGV
|
|
argument array, assignable;
|
|
non-null members are taken as filenames
|
|
.It Va CONVFMT
|
|
conversion format used when converting numbers
|
|
(default
|
|
.Qq %.6g )
|
|
.It Va ENVIRON
|
|
array of environment variables; subscripts are names.
|
|
.It Va FILENAME
|
|
the name of the current input file
|
|
.It Va FNR
|
|
ordinal number of the current record in the current file
|
|
.It Va FS
|
|
regular expression used to separate fields; also settable
|
|
by option
|
|
.Fl F Ar fs .
|
|
.It Va NF
|
|
number of fields in the current record
|
|
.It Va NR
|
|
ordinal number of the current record
|
|
.It Va OFMT
|
|
output format for numbers (default
|
|
.Qq "%.6g"
|
|
)
|
|
.It Va OFS
|
|
output field separator (default blank)
|
|
.It Va ORS
|
|
output record separator (default newline)
|
|
.It Va RS
|
|
input record separator (default newline)
|
|
.It Va SUBSEP
|
|
separates multiple subscripts (default 034)
|
|
.El
|
|
.Ss Functions
|
|
Functions may be defined (at the position of a pattern-action statement) thus:
|
|
.Bd -filled -offset indent
|
|
.Ic function foo(a, b, c) { ...; return x }
|
|
.Ed
|
|
.Pp
|
|
Parameters are passed by value if scalar and by reference if array name;
|
|
functions may be called recursively.
|
|
Parameters are local to the function; all other variables are global.
|
|
Thus local variables may be created by providing excess parameters in
|
|
the function definition.
|
|
.Sh EXAMPLES
|
|
.Bl -tag -width indent -compact
|
|
.It Ic length($0) > 72
|
|
Print lines longer than 72 characters.
|
|
.Pp
|
|
.It Ic { print $2, $1 }
|
|
Print first two fields in opposite order.
|
|
.Pp
|
|
.It Ic BEGIN { FS = \&",[ \et]*|[ \et]+\&" }
|
|
.It Ic "\ \ \ \ \ \ {" print \&$2, \&$1 }
|
|
Same, with input fields separated by comma and/or blanks and tabs.
|
|
.Pp
|
|
.It Ic "\ \ \ \ {" s += $1 }
|
|
.It Xo
|
|
.Ic END { print \&"sum is\&", s, \&" average is\ \&",\ s/NR\ }
|
|
.Xc
|
|
Add up first column, print sum and average.
|
|
.Pp
|
|
.It Ic /start/, /stop/
|
|
Print all lines between start/stop pairs.
|
|
.Pp
|
|
.It Ic BEGIN { # Simulate echo(1)
|
|
.It Ic "\ \ \ \ " for (i = 1; i < ARGC;\ i++)\ printf\ \&"%s\ \&",\ ARGV[i]
|
|
.It Ic "\ \ \ \ " printf \&"\en\&"
|
|
.It Ic "\ \ \ \ " exit }
|
|
.El
|
|
.Sh SEE ALSO
|
|
.Xr lex 1 ,
|
|
.Xr sed 1
|
|
.Pp
|
|
A. V. Aho, B. W. Kernighan, P. J. Weinberger,
|
|
.Em The AWK Programming Language ,
|
|
Addison-Wesley, 1988. ISBN 0-201-07981-X
|
|
.Sh BUGS
|
|
There are no explicit conversions between numbers and strings.
|
|
To force an expression to be treated as a number add 0 to it;
|
|
to force it to be treated as a string concatenate
|
|
\&\f(CW""\fP to it.
|
|
.br
|
|
The scope rules for variables in functions are a botch;
|
|
the syntax is worse.
|