Использование 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.

  • как использовать awk для вычитания с числами в большом файле
  • Удалить строку с специальными символами
  • Как извлечь первое целое из текстовой строки в столбце файла с разделителями табуляции?
  • Удалить строки, начинающиеся с #
  • sed: многострочная замена блока конфигурации
  • bash - извлекает имена файлов из html-файла, содержащего несколько ссылок
  • Извлечение нескольких экземпляров текста между двумя словами, включая стартовое слово, но исключающее слово
  • Как вложить глобальные совпадения с 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"' 
    Linux и Unix - лучшая ОС в мире.