一、awk内置变量
作用 | |
$0 | 代表目前awk所读入的郑航数据, 我们已知awk是一行一行读入数据的,$0就代表当前读入行的整行数据 |
$n | 代表目前读入行的第n个字段 |
NF | 当前行拥有的字段(列)总数 |
NR | 当前awk所处理的行,是总数据的第几行 |
FS | 用户定义分割符,awk的默认分隔符是任何空格, 如果想要使用其他分割符(如:)就需要FS变量定义 |
ARGC | 命令行参数个数 |
ARGV | 命令行参数数组 |
FNR | 当前文件中的当前记录数(对输入文件起始为1) |
OFMT | 数值的输出格式(默认%.6g) |
OFS | 输出字段的分割符(默认为空格) |
ORS | 输出记录分割符(默认为换行符) |
RS | 输入记录分割符(默认为换行符) |
二、awk内置变量实验
### --- 查询可以登录的用户的用户名和UID
[root@localhost ~]# cat /etc/passwd | grep "/bin/bash" | awk '{FS=":"} {printf $1 "\t" $3 "\n"}'
root:x:0:0:root:/root:/bin/bash
### --- 这里“:”分隔符生效了,可是第一行却没有起作用,原来我们忘记了“BEGIN”条件,那么再来试试:
[root@localhost ~]# cat /etc/passwd | grep "/bin/bash" | awk 'BEGIN {FS=":"} {printf $1 "\t" $3 "\n"}'
root 0
### --- 长BEGIN变量参数
~~~ 解释下 awk 命令
~~~ 开始执行{分隔符是“:”} {输出第一字段和第三字段 输出行号(NR 值) 字段数(NF 值)}
[root@localhost ~]# cat /etc/passwd | grep "/bin/bash" | awk 'BEGIN {FS=":"} {printf $1 "\t" $3 "\t 行号:" NR "\t 字段数:" NF "\n"}'
root 0 行号:1 字段数:7
root 0 行号:1 字段数:7
user1 501 行号:2 字段数:7
### --- 如果我只想看看 sshd 这个伪用户的相关信息,则可以这样使用:
~~~ 注:可以看到 sshd 伪用户的 UID 是 74,是/etc/passwd 文件的第 28 行,此行有 7 个字段
[root@localhost ~]# cat /etc/passwd | awk 'BEGIN {FS=":"} $1=="sshd" {printf $1 "\t" $3 "\t 行号:"NR "\t 字 段数:"F "\n"}'
sshd 74 行号:17 字 段数: