AWK - 漂亮的打印


到目前为止,我们已经使用 AWK 的printprintf函数在标准输出上显示数据。但 printf 比我们之前看到的要强大得多。该函数借用自 C 语言,在生成格式化输出时非常有用。以下是 printf 语句的语法 -

句法

printf fmt, expr-list

在上面的语法中,fmt是一个格式规范和常量的字符串。expr-list是与格式说明符对应的参数列表。

转义序列

与任何字符串类似,格式可以包含嵌入的转义序列。下面讨论的是 AWK 支持的转义序列 -

新队

以下示例使用换行符在单独的行中打印HelloWorld -

例子

[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 1显示为Field,因为最后一个字符被退格键删除。但是,最后一个字段Field 4按原样显示,因为Field 4之后没有\b

例子

[jerry]$ awk 'BEGIN { printf "Field 1\bField 2\bField 3\bField 4\n" }'

执行此代码时,您将得到以下结果 -

输出

Field Field Field Field 4

回车

在下面的示例中,打印每个字段后,我们执行回车并在当前打印值之上打印下一个值。这意味着,在最终输出中,您只能看到Field 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

%G格式使用%E而不是 %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

前导零

前导零充当标志,表示输出应该用零而不是空格填充。请注意,此标志仅在字段比要打印的值宽时才有效。下面的例子描述了这一点 -

例子

[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

哈希值

对于 %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