У меня в файле есть следующее содержимое: Это всего лишь некоторые временные метки
455860902
868790949
279116188
689905426
пример - я хотел бы получить следующий вывод
###########
sed -n '/455860902/,/868790949/p' file
sed -n '/868790949/,/279116188/p' file
sed -n '/279116188/,/689905426/p' file
Ему нужно пройти цикл, чтобы мне не приходилось sed
каждый раз вводить команду.
решение1
с использованием awk
:
awk 'prev{ print "sed -n \047/" prev "/,/" $0 "/p\047 file"; }
{ prev=$0 }' infile
решение2
Работает нормально, но не так хорошо, как предыдущий ответ.
la=`awk 'END{print NR}' filename`
co=$(($la - 1))
for i in `sed -n "1,"$co"p" filename`; do awk -v i="$i" '$1 ~ i {getline x;print "sed -n" " " "/"$0"/,/"x"/p"}' filename; done| sed "s/\//'&/"| sed "s/\/p/\/p'/g"
выход
sed -n '/455860902/,/868790949/p'
sed -n '/868790949/,/279116188/p'
sed -n '/279116188/,/689905426/p'