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

  • Как найти строки, содержащие более 100 символов, и содержит «if»?
  • команда bash, которая выводит результат предыдущего канала
  • Как заменить начальный ноль пробелом в SED?
  • Помощь с повторением поля A в CSV-файле, где поле B имеет указанное значение
  • присоединяйте два файла на основе столбца, когда в сценарии bash нет взаимно однозначного соответствия (awk, grep, sed)
  • Разделите базовое имя файла, сохраните часть каталога
  • Как анализировать файл данных для извлечения определенных данных и формата для другого использования?
  • sed count lines между шаблоном - несколько файлов
  • 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 - лучшая ОС в мире.