Linux之awk、变量、运算符、if多分支

一.awk语法

awk [options] 'commands' files

option

-F 定义字段分隔符,默认的分隔符是连续的空格或制表符

使用option中的-F参数定义间隔符号

用$1,$2,$3等的顺序表示files中每行以间隔符号分隔的各列不同域

NF变量表示当前记录的字段数

-v 定义变量并赋值 也可以借用次方式从shell变量中引入

二.变量

变量命名规则

以字母或下划线开头,剩下的部分可以是:字母、数字、下划线.

最好遵循下述规范:

1.以字母开头

2.使用中划线或者下划线做单词的连接

3.同类型的用数字区分

4.对于文件最好加上拓展名

NR 表示AWK读入的行数

FNR表示读入行所在文件中的行数

# awk '{print NR,FNR,$1}' file1 file2

1 1 aaaaa

2 2 bbbbb

3 3 ccccc

4 1 dddddd

5 2 eeeeee

6 3 ffffff

#

逻辑运算 可直接引用域进行运算

== >= <= != > < ~ !~

# awk 'NR==1 {print}' /etc/passwd

root:x:0:0:root:/root:/bin/bash

#

命令 {print $0}

读后处理 END {awk_cmd1;awk_cmd2;}

NR 当前记录的个数(全部文件连接后的统计)

FNR 当前记录的个数(仅为当前文件的统计,非全部)

FS 字段分隔符 默认为连续空格或制表符,可以使用多个不同的符号做分隔符 -F[:/]

OFS 输出字符的分隔符 默认是空格

# awk -F: 'OFS="=====" {print $1,$2}' /etc/passwd

root=====x

NF 当前读入行的字段个数

ORS 输出记录分隔符 默认是换行

# awk -F: 'ORS="=====" {print $1,$2}' /etc/passwd

root x=====bin x=====

FILENAME 当前文件名

引用shell变量的方法

# a=root

# awk -v var=$a -F: '$1 == var {print $0}' /etc/passwd

或者 把整个命令拆开传递,让shell变量外露,

# awk -F: '$1 == "'$a'" {print $0}' /etc/passwd

# a=NF

# awk -F: '{print $'$a'}' /etc/passwd

三.操作符

赋值

= += -= /= *=

逻辑与 逻辑或 逻辑非

&& || !

匹配正则或不匹配,正则需要用 /正则/ 包围住

~ !~

关系 比较字符串时要把字符串用双引号引起来

< <= > >= != ==

字段引用

$ 字段引用需要加$,而变量引用直接用变量名取

运算符

+ - * / % ++ --

转义序列

\\ \自身

\$ 转义$

\t 制表符

\b 退格符

\r 回车符

\n 换行符

\c 取消换行

四.if (条件) 动作

root

2

3

...

33

/home/seker

/bin/bash

36

条件 ? 动作1 : 动作2

expr?action1:action2

# awk -F: 'var=($3 >= 500)?$1:"system_user" {print $1"\t"$3"\t"var}' /etc/passwd

# awk -F: '{print ($3>500?$1:$2)}' /etc/passwd