获取列的最大和最小长度值和数据?

获取列的最大和最小长度值和数据?

在包含 10 个字段的制表符分隔文件中,如何获取字段的最小和最大长度以及数据值,如下所示:

Field1 : Min 5 max 10  abcde abcdefghij
Field2: Min 3 max 5    abc   abcde

答案1

以下脚本应该可以完成您的需要:

#!/usr/local/bin/bash

input=./input
row=0
while read -r line; do
    columns=( $line )
    ((row++))
    max=0
    min=${#line}
    vmax=
    vmin=
    for column in "${columns[@]}"; do
        ((${#column}>max)) && max=${#column} && vmax=$column
        ((${#column}<min)) && min=${#column} && vmin=$column
    done
    echo "Row${row}: Min $min max $max $vmin $vmax"
done<"$input"

鉴于此输入:

field0      field1     field2    field3   field4  field5  field6   field7    field8     field9
a           aa         aaa       aaaa     aaaaa   aaaaaa  aaaaaaa  aaaaaaaa  aaaaaaaaa  aaaaaaaaaa
bbbbbbbbbb  bbbbbbbbb  bbbbbbbb  bbbbbbb  bbbbbb  bbbbb   bbbb     bbb       bb         b

它将产生以下输出:

$ ./script.sh
Row1: Min 6 max 6 field0 field0
Row2: Min 1 max 10 a aaaaaaaaaa
Row3: Min 1 max 10 b bbbbbbbbbb

注意:如果一行有多个相同长度的字段,最终成为最小/最大长度行,它将输出该长度的第一个字段。 (在示例中,输入 row1 具有所有相等长度的字段,因此它将 field0 列为最小值和最大值)。

相关内容