awk+xxd-bash命令中ASCII换行字节的混淆



我对某些bash命令中出现的某些0a(即NLASCII字节(感到困惑。关于以下内容:

$ echo | sha1sum $1 | awk '{print $1;}' | xxd -r -ps > test.bin
$ echo | sha1sum $1 | awk '{print $1;}' > test.hex
$ xxd test.bin
00000000: adc8 3b19 e793 491b 1c6e a0fd 8b46 cd9f  ..;...I..n...F..
00000010: 32e5 92fc                                2...
$ xxd test.hex
00000000: 6164 6338 3362 3139 6537 3933 3439 3162  adc83b19e793491b
00000010: 3163 3665 6130 6664 3862 3436 6364 3966  1c6ea0fd8b46cd9f
00000020: 3332 6535 3932 6663 0a                   32e592fc.

是什么导致0a字节出现在test.hex中而不在test.bin中?

注意1:这是我一直在问自己的一个问题,遵循那里使用的解决方案:

在bash 中以二进制格式而不是明文十六进制将``sha```校验和输出转储到磁盘

注意2:我能够抑制0a字节,这不是问题所在,我只是好奇为什么它在一种情况下存在,而在另一种情况中不存在:

$ echo | sha1sum $1 | awk '{print $1;}' | head -c-1 > test_2.hex
$ xxd test_2.hex
00000000: 6164 6338 3362 3139 6537 3933 3439 3162  adc83b19e793491b
00000010: 3163 3665 6130 6664 3862 3436 6364 3966  1c6ea0fd8b46cd9f
00000020: 3332 6535 3932 6663                      32e592fc

您看到的0a来自awk。默认情况下,awk输出记录分隔符n,您可以通过设置ORS(例如使用BEGIN {ORS=""}(对其进行远程控制。

由于-r参数的原因,通过xxd -r -ps进行管道传输时会丢失它。从手册页:"任何地方都允许额外的空白和换行。">

最新更新