File 如何使用awk打印输入文件的特定部分

File 如何使用awk打印输入文件的特定部分,file,awk,File,Awk,我有一个这样的输入文件 # #mdrun is part of G R O M A C S: # #Go Rough, Oppose Many Angry Chinese Serial killers # @ title "dH/d\xl\f{}, \xD\f{}H" @ xaxis label "Time (ps)" @ s0 legend "dH/d\xl\f{} \xl\f{} 0.1" @ s1 legend "\xD\f{}H \xl\f{} 0.05" @ s2 leg

我有一个这样的输入文件

#
#mdrun is part of G R O M A C S:
#
#Go Rough, Oppose Many Angry Chinese Serial killers
#
@    title "dH/d\xl\f{}, \xD\f{}H"
@    xaxis  label "Time (ps)"
@ s0 legend "dH/d\xl\f{} \xl\f{} 0.1"
@ s1 legend "\xD\f{}H \xl\f{} 0.05"
@ s2 legend "\xD\f{}H \xl\f{} 0.15"
0.0000 -33.8598 1.71168 -1.66746
0.2000 -34.3949 1.73192 -1.702
0.4000 -31.8213 1.61262 -1.56193
0.6000 -32.3563 1.63639 -1.59224
0.8000 -33.6158 1.69898 -1.65539
1.0000 -32.5242 1.65055 -1.59363
1.2000 -33.7464 1.70708 -1.6607
1.4000 -33.0552 1.68563 -1.60985
1.6000 -32.9946 1.66834 -1.62445
1.8000 -31.6345 1.60933 -1.54529
2.0000 -33.1246 1.67736 -1.62769
2.2000 -33.9822 1.71743 -1.67394
2.4000 -32.4887 1.64732 -1.59384
2.6000 -30.0927 1.5349 -1.46508 
so on till 100000.0000
我想生成一个包含特定部分(完整行)的新文件,比如1000.0000-2000.0000,所有行都包含“@”和“#”。有人建议我使用awk并建议使用此代码

  awk '(/^1000/,/^2000/) || /^[@#]/{print;}' inputfile > outputfile
这显示了一个错误

  awk: line 1: syntax error at or near ||

我以前没有使用过awk,所以我不知道如何用awk编写代码。如果有人能建议如何用awk或其他类似sed的语言编写正确的代码。我将不胜感激

不能以这种方式将范围运算符
| |
组合,尽管在这种情况下有一种替代方法:

awk '/^1000/,/^2000/; /^[@#]/' inputfile > outputfile
分号分隔了这两个条件。对于每个为真的条件,将执行默认操作(打印行)。如果您的条件发生冲突(您将在输出中获得重复的行),这将是一个问题,但在这里不适用

一般来说,您可以使用变量确定要打印的行:

awk '/^1000/{f=1} f||/^[@#]/; /^2000/{f=0}' inputfile > outputfile

这涉及两个独立条件可能同时为真的情况。

Nice,适合我!!