首页 > 解决方案 > Linux命令从不以数字开头的文件中过滤记录

问题描述

我在 linux 中有一个文件。

它有很多记录

第一条记录是页眉,一些记录有数据记录,最后一条记录是页脚记录

记录.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

标签: linuxshell

解决方案


[1,9]意思是“一个字符1,或者9。这可能不是你的意思。也许你的意思是[19](一个或九个)或者你的意思是[0-9](任何数字)。我假设你的意思是“任何数字”,因为这就是你所说的标题。如果你的意思是别的,我希望如何解决它是显而易见的。

要反转可以匹配的字符集,^请在[. 所以[^0-9]意思是“除数字以外的任何东西”。

模式的^开头表示“仅匹配一行的开头”。但这仅意味着在模式的开头。

所以^[^0-9]匹配以非数字开头的行。

这些模式都不会匹配空行,因为它们都匹配一个字符。

通常,grep 在一行中的任意位置搜索模式,如果找到该模式,则打印该行。但是如果你把 a^放在模式的开头,它只会检查行的开头。您还可以$在模式的末尾放置 a 来表示“仅在行尾匹配”。如果你^在开头和$结尾都使用,你要求 grep 打印与模式精确匹配的行。对于这个问题,您不需要知道这一点,但它总有一天会派上用场。


推荐阅读