1598427@931
PDD 220624P00051000 ohlc=0,0,0,0 vol=0 oi=424 nbbo=69@2316/113@532 nbbo2=69@145/113@95
PDD 220617C00051000 ohlc=0,0,0,0 vol=0 oi=434 nbbo=530@1921/710@1496 nbbo2=530@31/710@115
PDD 220722P00051000 ohlc=0,0,0,0 vol=0 oi=15 nbbo=285@1436/405@1772 nbbo2=230@15/455@15
PDD 220708C00051000 ohlc=0,0,0,0 vol=0 oi=17 nbbo=785@864/935@894 nbbo2=785@15/935@15
PDD 220624C00051000 ohlc=0,0,0,0 vol=0 oi=392 nbbo=645@771/795@947 nbbo2=645@83/795@80
PDD 220729C00051000 ohlc=0,0,0,0 vol=0 oi=0 nbbo=870@902/1190@677 nbbo2=820@15/1195@20
PDD 220708P00051000 ohlc=0,0,0,0 vol=0 oi=32 nbbo=200@1413/320@2273 nbbo2=200@15/320@356
PDD 220722C00051000 ohlc=0,0,0,0 vol=0 oi=140 nbbo=795@1630/1175@1544 nbbo2=795@51/1175@21
PDD 220729P00051000 ohlc=0,0,0,0 vol=0 oi=11 nbbo=254@3/450@3 nbbo2=254@2/570@1
CSCO 220715C00090000 ohlc=0,0,0,0 vol=0 oi=739 nbbo=0@0/4@1056 nbbo2=0@0/4@121
CSCO 220617C00090000 ohlc=0,0,0,0 vol=0 oi=203 nbbo=0@0/1@2 nbbo2=0@0/0@0
CSCO 220617P00090000 ohlc=0,0,0,0 vol=0 oi=0 nbbo=4685@654/4730@1155 nbbo2=4685@33/4730@33
CSCO 240119P00090000 ohlc=0,0,0,0 vol=0 oi=0 nbbo=4695@202/4770@193 nbbo2=4695@75/4770@33
Run Code Online (Sandbox Code Playgroud)
我有一个与上面类似的文件。
我想找到包含单词CSCO
或长度的所有行<= 15
。
我可以使用什么命令来执行此操作?
grep -e CSCO -e '^.\{0,15\}$' filename
Run Code Online (Sandbox Code Playgroud)
这里你给 grep 两个要查找的模式。第一个是“CSCO”:因此它将匹配任何与之匹配的行。第二个查找行的开头,^
后跟任何.
出现 0 到 15 次的字符\{0,15\}
,然后是行的结尾$
。
如果 CSCO 必须是一个完整的“单词”,而不是较大单词或模式的一部分,您可以使用'\<CSCO\>'
or'\bCSCO\b'
或 ,具体'[[:<:]]CSCO[[:>:]]'
取决于您的grep
实现(\<
,\>
是最常支持的),所有这些都是在之间的转换处匹配的单词边界运算符一个单词字符(数字或下划线)和一个非单词字符(所有其他字符)。
对于grep -E
扩展正则表达式,您可以使用交替 ( |
)。
$ grep -E 'CSCO|^.{0,15}$' file
1598427@931
CSCO 220715C00090000 ohlc=0,0,0,0 vol=0 oi=739 nbbo=0@0/4@1056 nbbo2=0@0/4@121
CSCO 220617C00090000 ohlc=0,0,0,0 vol=0 oi=203 nbbo=0@0/1@2 nbbo2=0@0/0@0
CSCO 220617P00090000 ohlc=0,0,0,0 vol=0 oi=0 nbbo=4685@654/4730@1155 nbbo2=4685@33/4730@33
CSCO 240119P00090000 ohlc=0,0,0,0 vol=0 oi=0 nbbo=4695@202/4770@193 nbbo2=4695@75/4770@33
Run Code Online (Sandbox Code Playgroud)
如果您只想匹配位于行开头且后跟空格(空格、制表符等)的“CSCO”:
$ grep -E '^CSCO[[:space:]]|^.{0,15}$' file
Run Code Online (Sandbox Code Playgroud)
或者使用词尾边界标记,\>
(我不记得这是一个 GNU 扩展还是“标准”,并且很难用 google 搜索到。它绝对适用于 GNU grep,也许其他) :
$ grep -E '^CSCO\>|^.{0,15}$' file
Run Code Online (Sandbox Code Playgroud)
请注意,GNU grep 的信息文档将“单词”字符定义为[_[:alnum:]]
,这与手册页中的定义不同perlre
,perl 还将一些连接标点符号和 unicode 字符识别为“单词”。
如果您使用 GNU grep,该版本也可以理解 perl 的\s
(任何空格)和\b
(单词边界标记),即使使用-E
而不是-P
. GNU grep 的-P
PCRE 支持选项增加了\h
对水平空白的识别。例如
$ grep -E '^CSCO\s|^.{0,15}$' file
$ grep -E '^CSCO\b|^.{0,15}$' file
$ grep -P '^CSCO\h|^.{0,15}$' file
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
96 次 |
最近记录: |