循环遍历文件中的行并将变量递增到下一行

循环遍历文件中的行并将变量递增到下一行

我的文件中有以下内容:这些只是一些时间戳

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'

相关内容