到目前为止,我们已经使用AWK的 print 和 printf 函数来显示在标准输出的数据。但 printf 比我们以前见过强大得多。这个函数是从C语言借来的,是非常有帮助的,同时产生格式化输出。下面是 printf 语句的语法:
printf fmt, expr-list
在上面的语法fmt是格式规范和常量字符串。 expr-list是对应于格式说明符的参数列表。
转义序列
就像任何字符串,格式也可以包含嵌入转义序列。下面是由AWK支持转义序列的列表:
新的一行
下面的例子打印Hello 和 World 用换行符分开一行:
[jerry]$ awk 'BEGIN { printf "Hello\nWorld\n" }'
在执行上面的代码后,会得到以下结果:
Hello World
水平选项卡
下面的示例使用水平选项卡来显示在不同的字段中:
[jerry]$ awk 'BEGIN { printf "Sr No\tName\tSub\tMarks\n" }'
在执行上面的代码后,会得到以下结果:
Sr No Name Sub Marks
垂直选项卡
下面的示例使用在每个垂直选项卡字段后:
[jerry]$ awk 'BEGIN { printf "Sr No\vName\vSub\vMarks\n" }'
在执行上面的代码后,会得到以下结果:
Sr No Name Sub Marks
退格键
下面的例子打印,除了最后一个每个字段后,退格。这将擦除前三个Field的数字。例如Field1显示为Field,因为最后的字符被删除退格。然而,最后一个字段Field4显示,因为我们Field4后没有使用 a \b。
[jerry]$ awk 'BEGIN { printf "Field 1\bField 2\bField 3\bField 4\n" }'
在执行上面的代码后,会得到以下结果:
Field Field Field Field 4
回车
在下面的例子中,每次打印字段之后,做一个回车并打印对当前印刷值之上的下一个值。这意味着,在最后的输出,会看到只有4字段,因为它是印在前面所有的字段顶部的最后一件事。
[jerry]$ awk 'BEGIN { printf "Field 1\rField 2\rField 3\rField 4\n" }'
在执行上面的代码后,会得到以下结果:
Field 4
换页
下面的例子使用了换页在打印每个字段之后。
[jerry]$ awk 'BEGIN { printf "Sr No\fName\fSub\fMarks\n" }'
在执行上面的代码后,会得到以下结果:
Sr No Name Sub Marks
格式说明
像C语言AWK也有格式说明。AWK版本的printf语句中接受下列转换规范格式:
%c
它打印一个字符。如果用于%c的参数是数字,它被视为一个字符和打印。否则,参数被假定为一个字符串,该字符串的唯一第一字符被打印。
[jerry]$ awk 'BEGIN { printf "ASCII value 65 = character %c\n", 65 }'
在执行上面的代码后,会得到以下结果:
ASCII value 65 = character A
%d 和 %i
它打印的十进制数只有整数部分。
[jerry]$ awk 'BEGIN { printf "Percentags = %d\n", 80.66 }'
在执行上面的代码后,会得到以下结果:
Percentags = 80
%e 和 %E
它打印格式的浮点数[-] d.dddddde[+-]dd。
[jerry]$ awk 'BEGIN { printf "Percentags = %E\n", 80.66 }'
在执行上面的代码后,会得到以下结果:
Percentags = 8.066000e+01
%E格式使用E代替e。
[jerry]$ awk 'BEGIN { printf "Percentags = %e\n", 80.66 }'
在执行上面的代码后,会得到以下结果:
Percentags = 8.066000E+01
%f
它打印格式的浮点数 [-]ddd.dddddd.
[jerry]$ awk 'BEGIN { printf "Percentags = %f\n", 80.66 }'
在执行上面的代码后,会得到以下结果:
Percentags = 80.660000
%g 和 %G
使用%e或%f转换,以较短者为准,具有抑制非显著零。
[jerry]$ awk 'BEGIN { printf "Percentags = %g\n", 80.66 }'
在执行上面的代码后,会得到以下结果:
Percentags = 80.66
The %G format uses %E instead of %e.
[jerry]$ awk 'BEGIN { printf "Percentags = %G\n", 80.66 }'
在执行上面的代码后,会得到以下结果:
Percentags = 80.66
%o
它打印一个无符号的八进制数。
[jerry]$ awk 'BEGIN { printf "Octal representation of decimal number 10 = %o\n", 10}'
在执行上面的代码后,会得到以下结果:
Octal representation of decimal number 10 = 12
%u
它打印一个无符号的十进制数。
[jerry]$ awk 'BEGIN { printf "Unsigned 10 = %u\n", 10 }'
在执行上面的代码后,会得到以下结果:
Unsigned 10 = 10
%s
它打印字符串。
[jerry]$ awk 'BEGIN { printf "Name = %s\n", "Sherlock Holmes" }'
在执行上面的代码后,会得到以下结果:
Name = Sherlock Holmes
%x 和 %X
它打印一个无符号的十六进制数。在%X格式使用大写字母而不是小写。
[jerry]$ awk 'BEGIN { printf "Hexadecimal representation of decimal number 15 = %x\n", 15}'
在执行上面的代码后,会得到以下结果:
Hexadecimal representation of decimal number 15 = f
现在,让我们使用使用%X和观察结果:
[jerry]$ awk 'BEGIN { printf "Hexadecimal representation of decimal number 15 = %X\n", 15}'
在执行上面的代码后,会得到以下结果:
Hexadecimal representation of decimal number 15 = F
%%
它打印一个字符%,没有参数转换。
[jerry]$ awk 'BEGIN { printf "Percentags = %d%%\n", 80.66 }'
在执行上面的代码后,会得到以下结果:
Percentags = 80%
使用%的可选参数
使用%,我们可以使用下列可选参数:
宽度
该字段将被填充到宽度。默认情况下,字段用空格填充,但是当0标志时,它是用零填充。
[jerry]$ awk 'BEGIN { num1 = 10; num2 = 20; printf "Num1 = %10d\nNum2 = %10d\n", num1, num2 }'
在执行上面的代码后,会得到以下结果:
Num1 = 10 Num2 = 20
前导零
前导0(零)作为一个标志,表示输出应用零而不是空格填充。请注意,该标志只具有一个效果时,字段宽度大于要打印的值。下面的例子说明这一点:
[jerry]$ awk 'BEGIN { num1 = -10; num2 = 20; printf "Num1 = %05d\nNum2 = %05d\n", num1, num2 }'
在执行上面的代码后,会得到以下结果:
Num1 = -0010 Num2 = 00020
左对齐
表达式应该是左对齐的字段。紧接着%在数字之前- 当输入字符串小于指定的字符数,希望它是左对齐,即通过增加空间向右,使用减号(-)。在下面的例子中,AWK命令的输出管道到cat命令显示END OF LINE($)字符。
[jerry]$ awk 'BEGIN { num = 10; printf "Num = %-5d\n", num }' | cat -vte
在执行上面的代码后,会得到以下结果:
Num = 10 $
前缀符号
它总是前缀数字值用一个符号,即使该值是正的。
[jerry]$ awk 'BEGIN { num1 = -10; num2 = 20; printf "Num1 = %+d\nNum2 = %+d\n", num1, num2 }'
在执行上面的代码后,会得到以下结果:
Num1 = -10 Num2 = +20
Hash
对于%o,它提供一个前导零。对于%x和%X,它提供了一个0x或0X分别只有结果是零。对于%e, %E, %f 和%F,结果总是包含一个小数点。对于%g和%G,后边的零不会从结果中删除。下面简单的例子说明这一点:
[jerry]$ awk 'BEGIN { printf "Octal representation = %#o\nHexadecimal representaion = %#X\n", 10, 10}'
在执行上面的代码后,会得到以下结果:
Octal representation = 012 Hexadecimal representation = 0XA