linux awk 内置函数详细介绍(实例)
一、算术函数:
以下算术函数执行与 C 语言中名称相同的子例程相同的操作
函数名 | 说明 |
atan2( y, x ) | 返回 y/x 的反正切。 |
cos( x ) | 返回 x 的余弦;x 是弧度。 |
s( x ) | 返回 x 的正弦;x 是弧度。 |
exp( x ) | 返回 x 幂函数。 |
log( x ) | 返回 x 的自然对数。 |
sqrt( x ) | 返回 x 平方根。 |
t( x ) | 返回 x 的截断至整数的值。 |
rand( ) | 返回任意数字 n,其中 0 <= n < 1。 |
srand( [Expr] ) | 将 rand 函数的种子值设置为 Expr 参数的值,或如果省略 Expr 参数则使用某天的时间。返回先前的种子值。 |
复制代码
举例说明
[chengmo@centos5 ~]$ awk 'BEGIN{OFMT="%.3f";fs=s(1);fe=exp(10);fl=log(10);fi=t(3.1415);prt fs,fe,fl,fi;}'
0.841 22026.466 2.303 3 </p> <p>OFMT 设置输出数据格式是保留3位小数</p> <p>获得随机数</p> <p>[chengmo@centos5 ~]$ awk 'BEGIN{srand();fr=t(100rand());prt fr;}'
78
[chengmo@centos5 ~]$ awk 'BEGIN{srand();fr=t(100rand());prt fr;}'
31
[chengmo@centos5 ~]$ awk 'BEGIN{srand();fr=t(100rand());prt fr;}'
41
二、字符串函数是
函数 | 说明 |
gsub( Ere, Repl, [ In ] ) | 除了正则表达式所有具体值被替代这点,它和 sub 函数完全一样地执行,。 |
sub( Ere, Repl, [ In ] ) | 用 Repl 参数指定的字符串替换 In 参数指定的字符串中的由 Ere 参数指定的扩展正则表达式的第一个具体值。sub 函数返回替换的数量。出现在 Repl 参数指定的字符串中的 &(和符号)由 In 参数指定的与 Ere 参数的指定的扩展正则表达式匹配的字符串替换。如果未指定 In 参数,缺省值是整个记录($0 记录变量)。 |
dex( Strg1, Strg2 ) | 在由 Strg1 参数指定的字符串(其中有出现 Strg2 指定的参数)中,返回位置,从 1 开始编号。如果 Strg2 参数不在 Strg1 参数中出现,则返回 0(零)。 |
length [(Strg)] | 返回 Strg 参数指定的字符串的长度(字符形式)。如果未给出 Strg 参数,则返回整个记录的长度($0 记录变量)。 |
blength [(Strg)] | 返回 Strg 参数指定的字符串的长度(以字节为单位)。如果未给出 Strg 参数,则返回整个记录的长度($0 记录变量)。 |
substr( Strg, M, [ N ] ) | 返回具有 N 参数指定的字符数量子串。子串从 Strg 参数指定的字符串取得,其字符以 M 参数指定的位置开始。M 参数指定为将 Strg 参数中的第一个字符作为编号 1。如果未指定 N 参数,则子串的长度将是 M 参数指定的位置到 Strg 参数的末尾 的长度。 |
match( Strg, Ere ) | 在 Strg 参数指定的字符串(Ere 参数指定的扩展正则表达式出现在其中)中返回位置(字符形式),从 1 开始编号,或如果 Ere 参数不出现,则返回 0(零)。RSTART 特殊变量设置为返回值。RLENGTH 特殊变量设置为匹配的字符串的长度,或如果未找到任何匹配,则设置为 -1(负一)。 |
split( Strg, A, [Ere] ) | 将 Strg 参数指定的参数分割为数组元素 A[1], A[2], . . ., A[n],并返回 n 变量的值。此分隔可以通过 Ere 参数指定的扩展正则表达式进行,或用当前字段分隔符(FS 特殊变量)来进行(如果没有给出 Ere 参数)。除非上下文指明特定的元素还应具有一个数字值,否则 A 数组中的元素用字符串值来创建。 |
tolower( Strg ) | 返回 Strg 参数指定的字符串,字符串中每个大写字符将更改为小写。大写和小写的映射由当前语言环境的 LC_CTYPE 范畴定义。 |
toupper( Strg ) | 返回 Strg 参数指定的字符串,字符串中每个小写字符将更改为大写。大写和小写的映射由当前语言环境的 LC_CTYPE 范畴定义。 |
sprtf(Format, Expr, Expr, . . . ) | 根据 Format 参数指定的 prtf 子例程格式字符串来格式化 Expr 参数指定的表达式并返回生成的字符串。 |
Ere都可以是正则表达式
gsub,sub使用
[chengmo@centos5 ~]$ awk 'BEGIN{fo="this is a test2010test!";gsub(/[0-9]+/,"!",fo);prt fo}'
this is a test!test!
在 fo中查找满足正则表达式,/[0-9]+/ 用””替换,并且替换后的值,赋值给fo 未给fo值,默认是$0
查找字符串(dex使用)
[wangsl@centos5 ~]$ awk 'BEGIN{fo="this is a test2010test!";prt dex(fo,"test")?"ok":"no found";}'
ok
未找到,返回0
正则表达式匹配查找(match使用)
[wangsl@centos5 ~]$ awk 'BEGIN{fo="this is a test2010test!";prt match(fo,/[0-9]+/)?"ok":"no found";}'
ok
截取字符串(substr使用)
[wangsl@centos5 ~]$ awk 'BEGIN{fo="this is a test2010test!";prt substr(fo,4,10);}'
s is a tes
从第 4个 字符开始,截取10个长度字符串
字符串分割(split使用)
[chengmo@centos5 ~]$ awk 'BEGIN{fo="this is a test";split(fo,tA," ");prt length(tA);for(k tA){prt k,tA[k];}}'
4
4 test
1 this
2 is
3 a
分割fo,动态创建数组tA,这里比较有意思,awk for … 循环,是一个无序的循环。 并不是从数组下标1…n ,使用时候需要注意。
格式化字符串输出(sprtf使用)
格式化字符串格式
其中格式化字符串包括两部分内容: 一部分是正常字符, 这些字符将按原样输出; 另一部分是格式化规定字符, 以"%"开始, 后跟一个或几个规定字符,用来确定输出内容格式。
格式符 | 说明 |
%d | 十进制有符号整数 |
%u | 十进制无符号整数 |
%f | 浮点数 |
%s | 字符串 |
%c | 单个字符 |
%p | 指针的值 |
%e | 指数形式的浮点数 |
%x | %X 无符号以十六进制表示的整数 |
%o | 无符号以八进制表示的整数 |
%g | 自动选择合适的表示法 |
复制代码