我正在处理一个bash脚本,我想并排打印两个文件。一个文件填充IPv4地址,另一个文件填充IPv6地址。我试过了,
pr -mtw $WIDTH $FILE1 $FILE2
但它削减了产量。
┌────┤IPV4├─────┬─────────────────┤IPV6├────────────────┐
224.0.0.1 2001:0db8:0000:
192.0.2.128 ff02::1
192.0.2.128 2001:0db8:0000:
192.0.2.128 ::
2001:0db8:0000:
2001:db8:0:0:0:
2001:db8::ff00:
0000:0000:0000:
::1
fe80::
::ffff:192.0.2.
::192.0.2.128
我也试过了,
paste $FILE1 $FILE2 | awk '$1=$1' OFS='\t '
而输出是,
┌────┤IPV4├─────┬─────────────────┤IPV6├────────────────┐
224.0.0.1 2001:0db8:0000:0042:0000:8a2e:0370:7334
192.0.2.128 ff02::1
192.0.2.128 2001:0db8:0000:0000:0000:ff00:0042:8329
192.0.2.128 ::
2001:0db8:0000:0000:0000:ff00:0042:8329
2001:db8:0:0:0:ff00:42:8329
2001:db8::ff00:42:8329
0000:0000:0000:0000:0000:0000:0000:0001
::1
fe80::
::ffff:192.0.2.128
::192.0.2.128
我希望输出是这样的,
┌────┤IPV4├─────┬─────────────────┤IPV6├────────────────┐
224.0.0.1 2001:0db8:0000:0042:0000:8a2e:0370:7334
192.0.2.128 ff02::1
192.0.2.128 2001:0db8:0000:0000:0000:ff00:0042:8329
192.0.2.128 ::
2001:0db8:0000:0000:0000:ff00:0042:8329
2001:db8:0:0:0:ff00:42:8329
2001:db8::ff00:42:8329
0000:0000:0000:0000:0000:0000:0000:0001
::1
fe80::
::ffff:192.0.2.128
::192.0.2.128
菲尔1:
224.0.0.1
192.0.2.128
192.0.2.128
192.0.2.128
FILE2:
2001:0db8:0000:0042:0000:8a2e:0370:7334
ff02::1
2001:0db8:0000:0000:0000:ff00:0042:8329
::
2001:0db8:0000:0000:0000:ff00:0042:8329
2001:db8:0:0:0:ff00:42:8329
2001:db8::ff00:42:8329
0000:0000:0000:0000:0000:0000:0000:0001
::1
fe80::
::ffff:192.0.2.128
::192.0.2.128
请注意,每行的开头都有一个空格。有任何想法吗?
使用awk
,tr
和GNU paste
命令: -
$ paste file1 file2 | awk -v FS='\t' '{printf("%-15s %s\n",$1,$2)}' | \
awk '{sub(/^/, " ", $0)}1'
224.0.0.1 2001:0db8:0000:0042:0000:8a2e:0370:7334
192.0.2.128 ff02::1
192.0.2.128 2001:0db8:0000:0000:0000:ff00:0042:8329
192.0.2.128 ::
2001:0db8:0000:0000:0000:ff00:0042:8329
2001:db8:0:0:0:ff00:42:8329
2001:db8::ff00:42:8329
0000:0000:0000:0000:0000:0000:0000:0001
::1
fe80::
::ffff:192.0.2.128
::192.0.2.128
您可以使用第二个优化最后一个管道awk
,不确定如何做到这一点。否则,这有效!
您可以使用命令column
:
paste -d, file1 file2 | column -s',' -n -t
paste
命令将使用分隔符,
逐行连接两个文件。
column命令将用必要的空格替换,
以使其正确缩进(使用选项-t
)。 -n
正在对column
填补空栏。请注意选项-n
is Debian具体。
这很好用
paste "$FILE1" "$FILE2" | awk -F'\t' '{printf("%-16s%s\n", $1, $2)}'