从文件中捕获序列的开头

Gil*_*Gil 6 bash awk grep sed

我有一个文本文件,如下所示:

      125
      126
      127    {
      566
      567
      568
      569       # blah blah
      570    {  #blah blah
      700
      701    {
Run Code Online (Sandbox Code Playgroud)

数字是左对齐的,模式在增加的意义上总是相同,最后是花括号.我只需要捕获起始数字.大括号总是被找到并限于序列结尾.文件的开头如图所示从'125'开始.

总之我需要:

      125
      566
      700
Run Code Online (Sandbox Code Playgroud)

我想出了什么:

      grep -A1 '{' | grep -v '{' | grep -oE '(^[0-9]+?)'
Run Code Online (Sandbox Code Playgroud)

但这省略了'125',但我通过在头部附加换行并插入一个来克服{.

我希望将其减少为单个正则表达式.

欢迎提出建议和更好的算法

小智 4

awk 'BEGIN {p=1} p==1 {print $1;p=0} $0~/{/ {p=1}'

Output:
125
566
700
Run Code Online (Sandbox Code Playgroud)

考虑到上面的文件格式,您可以使用 awk 和变量/标志来跟踪何时找到空位{