测试文件
cat text.txt
09:00:00 TESTING
09:00:01 TESTING
09:00:02 TESTING
09:00:03 TESTING
09:00:04 TESTING
09:01:00 TESTING
09:01:01 TESTING
09:01:02 TESTING
09:01:03 TESTING
09:02:00 TESTING
09:02:01 TESTING
09:02:02 TESTING
09:02:03 TESTING
09:03:00 TESTING
09:03:01 TESTING
09:03:02 TESTING
09:03:03 TESTING
Run Code Online (Sandbox Code Playgroud)
没有变量的实际模式搜索工作正常:
cat ./text.txt|awk -v start="09:01" -v end="09:02" '/09:01/,/09:02/' text.txt
09:01:00 TESTING
09:01:01 TESTING
09:01:02 TESTING
09:01:03 TESTING
09:02:00 TESTING
Run Code Online (Sandbox Code Playgroud)
使用失败的变量进行模式搜索
awk -v start="09:01" -v end="09:02" '/start/,/end/' text.txt
Run Code Online (Sandbox Code Playgroud)
讨厌的hack使用shell echo包装变量,使其工作
echo "awk -v start="09:01" -v end="09:02" '/$start/,/$end/' text.txt"
awk -v start=09:01 -v end=09:02 '/09:01/,/09:02/' text.txt
start="09:01"; end="09:02"; echo "awk -v start="09:01" -v end="09:02 text.txt" '/$start/,/$end/'"|/bin/sh
09:01:00 TESTING
09:01:01 TESTING
09:01:02 TESTING
09:01:03 TESTING
09:02:00 TESTING
Run Code Online (Sandbox Code Playgroud)
关于我做错了什么或者这是awk中可能的功能的任何想法?
这些建议有效,我在结果上有所不同:
1.
awk -v start="09:01" -v end="09:02" '$0~start,$0~end' text.txt
09:01:00 TESTING
09:01:01 TESTING
09:01:02 TESTING
09:01:03 TESTING
09:02:00 TESTING
Run Code Online (Sandbox Code Playgroud)
2.
awk -v start="09:01" -v end="09:02" 'match($0,start),match($0,end)' text.txt
09:01:00 TESTING
09:01:01 TESTING
09:01:02 TESTING
09:01:03 TESTING
09:02:00 TESTING
Run Code Online (Sandbox Code Playgroud)
3.
awk -v start="09:01" -v end="09:02" '$0~start{print}$0~end{print}' text.txt
09:01:00 TESTING
09:01:01 TESTING
09:01:02 TESTING
09:01:03 TESTING
09:02:00 TESTING
09:02:01 TESTING
09:02:02 TESTING
09:02:03 TESTING
Run Code Online (Sandbox Code Playgroud)
4.
awk -v start="09:01" -v end="09:02" '$1~start||$1~end' text.txt
09:01:00 TESTING
09:01:01 TESTING
09:01:02 TESTING
09:01:03 TESTING
09:02:00 TESTING
09:02:01 TESTING
09:02:02 TESTING
09:02:03 TESTING
Run Code Online (Sandbox Code Playgroud)
3和4返回完整的结果,前两个一旦到达模式就停止
您需要将变量锚定到行的开头:
awk -v start="09:01" -v end="09:02" '$0~"^"start,$0~"^"end' text.txt
Run Code Online (Sandbox Code Playgroud)
所以09:02匹配09:02:01而不是17:09:02
我个人不会使用这个范围的东西,而是在适当的时候设置/清除/测试一个标志,因为它更具有可扩展性.例如,尝试其中的每一个,看看操纵打印是否容易,或者不是划分线:
awk -v start="09:01" -v end="09:02" '$0~"^"start{f=1} f; $0~"^"end{f=0}' text.txt
awk -v start="09:01" -v end="09:02" 'f; $0~"^"start{f=1} $0~"^"end{f=0}' text.txt
awk -v start="09:01" -v end="09:02" '$0~"^"start{f=1} $0~"^"end{f=0} f;' text.txt
awk -v start="09:01" -v end="09:02" '$0~"^"end{f=0} f; $0~"^"start{f=1}' text.txt
Run Code Online (Sandbox Code Playgroud)
我看到你接受@sudo_Os的回答,你可能希望得到所有的09:02次,而不是停在第一次.如果这是真的,只需使用字符串而不是RE比较:
$ awk -v start="09:01" -v end="09:02" '$1>=start":00" && $1<=end":59"' file
09:01:00 TESTING
09:01:01 TESTING
09:01:02 TESTING
09:01:03 TESTING
09:02:00 TESTING
09:02:01 TESTING
09:02:02 TESTING
09:02:03 TESTING
Run Code Online (Sandbox Code Playgroud)
或者这会得到相同的结果:
$ awk -F: -v start="09:01" -v end="09:02" '$1FS$2>=start && $1FS$2<=end' file
Run Code Online (Sandbox Code Playgroud)