我在linux中有一个文件。
它有很多记录
第一条记录是页眉,有些记录有数据记录,最后一条记录是页脚记录。
records.txt
1MJ M062021
JKYCNY MJ 0621 0000000002 00000001000 00000000100
MYFCNT MJ 0621 0000000003 00000003000 00000000100
JKYCNY MJ 0621 0000000004 00000010000 00000000100
JKYCNY MJ 0621 0000000005 00000025000 00000000100
aYFCNT MJ 0621 0000000006 00000001000 00000000100
JKYCNY MJ 0621 0000000007 00000003000 00000000100
MYFCNT MJ 0621 0000000008 00000010000 00000000100
JKYCNY MJ 0621 0000000009 00000005000 00000000100
JKYCNY MJ 0621 0000000010 00000010000 0000000010
JKYCNY MJ 0621 0000043199 00000000100 00000000100
JKYCNY MJ 0621 0000043200 00000000100 00000000100
9000000000042723我只想要数据记录,我想跳过头记录和尾记录,有时在这个文件中不会有头记录。
我只想获取数据记录,并将结果存储为文件。
下面的命令只给出页眉和页脚记录,
grep "^[1,9]" records.txt但是,单独跳过这两条记录的命令是什么,我尝试了下面的命令,但是没有帮助。
grep "!^[1,9]" records.txt发布于 2021-06-28 06:09:08
试试grep "^[^19]" records.txt
发布于 2021-06-28 06:43:58
有点像
grep -v '^[0-9]'这将写入第一个字符不是数字的所有行。
发布于 2021-06-28 09:21:59
所有的答案似乎都很好。只是想增加另一个选项。sed
sed -En '/^([[:alpha:]]+\s+)+/p' records.txt要就地编写并创建备份:
sed -Eni.bak '/^([[:alpha:]]+\s+)+/p' records.txthttps://stackoverflow.com/questions/68158301
复制相似问题