BASH 如何从每一行中获取最小值

BASH How to get minimum value from each row

我有这样的 csv 文件:

-0.106992, -0.106992, -0.059528, -0.059528, -0.028184, -0.028184, 0.017793, 0.017793, 0.0, 0.220367
-0.094557, -0.094557, -0.063707, -0.063707, -0.020796, -0.020796, 0.003707, 0.003707, 0.200767, 0.200767
-0.106038, -0.106038, -0.056540, -0.056540, -0.015119, -0.015119, 0.032954, 0.032954, 0.237774, 0.237774
-0.049499, -0.049499, -0.006934, -0.006934, 0.026562, 0.026562, 0.067442, 0.067442, 0.260149, 0.260149
-0.081001, -0.081001, -0.039581, -0.039581, -0.008817, -0.008817, 0.029912, 0.029912, 0.222084, 0.222084
-0.046782, -0.046782, -0.000180, -0.000180, 0.030788, 0.030788, 0.075928, 0.075928, 0.266452, 0.266452
-0.082107, -0.082107, -0.026791, -0.026791, 0.001874, 0.001874, 0.052341, 0.052341, 0.249779, 0.249779

enter image description here

我想从每一行中获取最小值。

预期输出必须是:

-0.106992

-0.094557

-0.106038

-0.049499

-0.08100

-0.046782

-0.082107

我尝试通过 awk 获取它,但 awk 没有给出最小值:

awk 命令:

awk '{m=; for (i=2; i<=NF; i++) if ($i < m) m = $i; print m}' file_name

输出:

-0.028184,

-0.020796,

-0.015119,

-0.006934,

-0.008817,

-0.000180,

-0.026791,

和ruby:-D

ruby -F', ' -ane 'puts $F.map(&:to_f).min' file.csv

Perl 简化了这个:

perl -MList::Util=min -F', ' -E 'say min @F' file.csv
-0.106992
-0.094557
-0.106038
-0.049499
-0.081001
-0.046782
-0.082107

在每个 Unix 框上的任何 shell 中使用任何 awk,无论每个逗号后是否有空格:

$ awk -F', *' '{min=; for (i=2;i<=NF;i++) if ($i<min) min=$i; print min}' file
-0.106992
-0.094557
-0.106038
-0.049499
-0.081001
-0.046782
-0.082107

您的代码正确:

awk '{m=; for (i=2; i<=NF; i++) if ($i < m) m = $i; print m}' file_name

除了您必须在字段分隔符中添加一个逗号:

awk -F '[[:blank:],]' '{m=; for (i=2; i<=NF; i++) if ($i < m) m = $i; print m}' file_name

[[:blank:],] 是空格、制表符和逗号。