awk: выводить по одной строке на каждое значение поля 1 (отдельное), где разница «поле-2 - поле-3» минимальна

Возможно, вам придется убрать пробел после NUM, так что сценарий должен выглядеть так:

#!/bin/bash
NUM=0
echo $NUM > text.txt
2
10.07.2017, 23:55
2 ответа

Наслаждайтесьawkрешением:

awk -F, '{ diff=$2-$3; if(a[$1]>diff || !a[$1]) { a[$1]=diff; b[$1]=$2 FS $3 } }
         END{ for(i in a) print i,b[i] }' OFS=',' yourfile

Выход:

c1,5,3
c2,8,4
2
27.01.2020, 22:09

Два -передают команду Awk, довольно грязно:

awk -F, 'FNR == NR {diff[NR] = $2-$3;
         if (!($1 in minline) || diff[NR] < diff[minline[$1]]) {
           minline[$1]=NR}; next}
         FNR == 1 {for (a in minline) {p[minline[a]]}}
         FNR in p' file.csv file.csv

Для интереса, вот как это сделать с помощью SQL (, сделанного в Postgres, если быть точным):

vagrant=# \d quick 
   Table "pg_temp_2.quick"
 Column |  Type   | Modifiers 
--------+---------+-----------
 f1     | text    | 
 f2     | integer | 
 f3     | integer | 

vagrant=# select * from quick;
 f1 | f2 | f3 
----+----+----
 c1 |  5 |  2
 c1 |  5 |  3
 c1 |  5 |  1
 c2 |  8 |  3
 c2 |  8 |  4
(5 rows)

vagrant=# select f1, f2, f3 from (select *, rank() over (partition by f1 order by f2 - f3) from quick) as x where rank = 1;
 f1 | f2 | f3 
----+----+----
 c1 |  5 |  3
 c2 |  8 |  4
(2 rows)

vagrant=# 

0
27.01.2020, 22:09

Теги

Похожие вопросы