BASH:同时并排显示两个文件

问题描述 投票:5回答:3

我正在处理一个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

请注意,每行的开头都有一个空格。有任何想法吗?

bash text awk
3个回答
2
投票

使用awktrGNU 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,不确定如何做到这一点。否则,这有效!


1
投票

您可以使用命令column

paste -d, file1 file2 | column  -s',' -n -t

paste命令将使用分隔符,逐行连接两个文件。

column命令将用必要的空格替换,以使其正确缩进(使用选项-t)。 -n正在对column填补空栏。请注意选项-nis Debian具体。


1
投票

这很好用

paste "$FILE1" "$FILE2" | awk -F'\t' '{printf("%-16s%s\n", $1, $2)}'
© www.soinside.com 2019 - 2024. All rights reserved.