Использование sed для консолидации разностного вывода

У меня есть этот результат в результате сравнения файлов с diff :

 < IF-Name :STRING: "lns-wall-01-t2" Index:Gge32: 260 --- > IF-Name :STRING: "lns-wall-01-t2" Index:Gge32: 25 

Мне нужен этот вывод:

 lns-wall-01-t2 old:260 new:25 

Я хочу использовать sed.

3 Solutions collect form web for “Использование sed для консолидации разностного вывода”

С awk :

 awk ' /^</ { old = $NF } /^>/ { str = $4 ; gsub(/"/,"",str) ; printf "%s old:%s new:%s\n", str, old, $NF } ' your_files_list_here 
 sed ' /^</{ # first line formatting s/^.*"\(.*\)".*: /\1 old:/ # append next 2 lines N N # exchange from 2nd line begining till last ":" by "new" s/\n---.*: / new:/ }' "$Rep_Scripts"/diff.txt 

используйте другой тип выходного сигнала:

 diff -y --suppress-common-lines f1 f2 

который дает вам более удобный для пользователя формат:

 F-Name :STRING: "lns-wall-01-t2" Index:Gge32: 260 |IF-Name :STRING: "lns-wall-01-t2" Index:Gge32: 25 

а также

 diff -y ........ | perl -nE '/"(.*?)".*?32:\s*(\d+).*32:\s*(\d+)/ and say "$1 old:$2 new:$3"' 
  • Разделите базовое имя файла, сохраните часть каталога
  • BSD sed: заменить только N-е вхождение шаблона
  • ksh / bash Форматирование файлов через sed по файлу cat | команда sed
  • добавьте «#» в начале выбранных строк в файле
  • Как изменить все строки в файле python от snake_case до camelCase в sed
  • Добавить кавычки и новый разделитель вокруг слов, разделенных пробелами
  • Как я могу группировать числа в файле
  • Сопоставьте начало линии с чем-то там?
  • Как ускорить работу скрипта на основе поиска grep?
  • Как удалить первую точку перед первым номером?
  • Вставить текст в определенные строки файла?
  • Linux и Unix - лучшая ОС в мире.