Страница 1 из 1

сбор значений из 2-х списков

Добавлено: 2012-08-03 8:41:10
mmvds
Есть собранная инфа по snmp о модели устройства
Проблема в том что snmp на устройствах разные, где-то есть одно комьюнити, где-то другое, где-то и то и другое, а гдето ни того ни другого.
В итоге в есть 2 списка вида ip|модель_устройства
там где есть первое комьюнити - есть модель устройства в первом списке, там где его нет, значение после Ip пустое, во втором списке соответственно наоборот
так вот, хочу сделать единый список, включающий инфу по всем устройствам, если инфы нет ни в том ни в другом списке, все-равно добавить эту пустую запись или как то ее пометить.
например
Есть
lst1.txt
10.1.2.1|model 1
10.1.2.2|
10.1.2.3|model 2
10.1.2.4|
10.1.2.5|model 1
10.1.2.6|
И
lst2.txt
10.1.2.1|model 1
10.1.2.2|model 2
10.1.2.3|
10.1.2.4|
10.1.2.5|model 1
10.1.2.6|model 3

хочу получить
lst3.txt
10.1.2.1|model 1
10.1.2.2|model 2
10.1.2.3|model 2
10.1.2.4|
10.1.2.5|model 1
10.1.2.6|model 3
или
lst3.txt
10.1.2.1|model 1
10.1.2.2|model 2
10.1.2.3|model 2
10.1.2.4|nosnmp
10.1.2.5|model 1
10.1.2.6|model 3

пробовал join'ом, не сообразил как

Re: сбор значений из 2-х списков

Добавлено: 2012-08-03 11:36:04
kpp

Код: Выделить всё

sort -u -r lst1.txt lst2.txt | sort -t"|" -u +0 -1 > lst3.txt
join в данном случае не подходит.
Я уже как-то высказывался на счет join - утилита полезная, но в ней нехватает как минимум возможности задать отличный от пробела символ разделителя полей. И с кириллицей не очень дружит.

Re: сбор значений из 2-х списков

Добавлено: 2012-08-03 11:42:04
kpp
А вот sort - мощнейшая и очень продуманная утилита. Рекомендую.

Re: сбор значений из 2-х списков

Добавлено: 2012-08-03 12:05:08
mmvds
kpp, спасибо! как всегда, выручили

Re: сбор значений из 2-х списков

Добавлено: 2012-08-03 12:30:18
mmvds
а еще подскажите плиз, что обозначает "+0 -1"? в man такого не нашел

Re: сбор значений из 2-х списков

Добавлено: 2012-08-03 12:55:50
kpp
"+0 -1" определяет ключ сортировки - первое поле. Нумерация полей начинается с нуля.
Читается так: "ключ сортировки начинается с нулевого поля, заканчивается первым полем"
Можно записать в другом виде: "-k1,1" - ключ сортировки - 1-е поле. В такой записи нумерация полей начинается с единицы.

Re: сбор значений из 2-х списков

Добавлено: 2012-08-03 15:35:58
mmvds
спасибо!