Удалить определенные объекты из базы данных плоских файлов

Удалить определенные объекты из базы данных плоских файлов

У меня есть база данных в виде плоского файла, и мне нужно удалить из нее некоторые объекты.

В файле много блоков, но меня интересуют 2 объекта в OBJECT NickCoreблоке.

Пример ниже:

OBJECT NickCore
DATA display SomeUser
DATA pass sha256:2b35341220119fad48762e4f843d1544354f8b196cf09bf1b4ea39f9a31be063:5ff60fae76026907102419460aae83aa74daf374048940b612ef83460043b565
DATA email [email protected]
DATA language
DATA access SomeUsero@*.5A5E5CBA.81D21A52.IP
DATA memomax 20
DATA MEMO_SIGNON 1
DATA MEMO_RECEIVE 1
DATA HIDE_EMAIL 1
DATA HIDE_MASK 1
DATA NS_PRIVATE 1
DATA AUTOOP 1
DATA KILLPROTECT 1
DATA NS_SECURE 1
END

Я хочу удалить DATA displayи DATA passиз каждого OBJECT NickCoreблока в файле.

Требуемый вывод будет просто разделен запятыми:

SomeUser,sha256:2b35341220119fad48762e4f843d1544354f8b196cf09bf1b4ea39f9a31be063:5ff60fae76026907102419460aae83aa74daf374048940b612ef83460043b565

Что мне для этого использовать?

решение1

С помощью GNU sed:

sed -n '/^OBJECT NickCore/,/^END/{s/^DATA display //;Ta;h;:a;s/DATA pass //;Tb;H;g;s/\n/,/p;:b}' file

Видеть:man sed

решение2

perl 1-строчник:

perl -lne '$u=$1 if(/^DATA display (\S+)/);print "$u,$1" if(/^DATA pass (\S+)/)' filename

Связанный контент