2017-10-12 107 views
0

我有一个日志文件包含所有信息。如何使用bash中的parametres从文件中提取行

2017-09-21 02:01:11,130 [http-nio-8080-exec-5] INFO - Inbound Message 
... 
... 
2017-09-21 09:01:11,130 [http-nio-8080-exec-5] INFO - Inbound Message 
---------------------------- 
ID: 6044 
Address: http://localhost/serveur/Service?wsdl 
Encoding: UTF-8 
Http-Method: POST 
... 
2017-09-21 12:01:11,130 [http-nio-8080-exec-5] INFO - Inbound Message 
... 

我想只提取2个日期之间的信息。对于为例,如果我想2017年9月21日09 ..和2017年9月21日12之间的信息我想有这样的事情:

./script.sh 2017-09-21 09 2017-09-21 12 
# $1 = 2017-09-21 
# $2 = 09 
# $3 = 2017-09-21 
# $4 = 12 
# $1 & 2 are date and hour to begin extract 
# $3 & 4 are date and hour to finish extract 

我的剧本是这样的。我没有shell编程知识,但我试图做到这一点。不幸的是它不起作用

#!/bin/bash 

beginLine = "$1 $2" 
finishLine = "$3 $4" 

while read fileLog.log 
do 
    if($fileLog.log grep beginLine) 
     echo $fileLog.log >> extractedlog.log 
    fi 
    if($fileLog.log grep finishLine) 
     < extractedLog.log; 
    fi 
done 
exit 0; 

有谁能告诉我问题在哪里?

+0

这不是'bash'语法 – hek2mgl

回答

2
$ awk '/2017-09-21 09/{a=1};a;/2017-09-21 12/{exit}' input 
2017-09-21 09:01:11,130 [http-nio-8080-exec-5] INFO - Inbound Message 
---------------------------- 
ID: 6044 
Address: http://localhost/serveur/Service?wsdl 
Encoding: UTF-8 
Http-Method: POST 
... 
2017-09-21 12:01:11,130 [http-nio-8080-exec-5] INFO - Inbound Message 

更多替代发现here

2

sed的方法(匹配/.../,/.../的范围的图案):

sed -n '/2017-09-21 09/,/2017-09-21 12/p' logfile 

----------

同样可以用awk(甚至更短):

awk '/2017-09-21 09/,/2017-09-21 12/' logfile 
+0

而放弃匹配2017年9月21日12我应该使用/ q是之后的过程? – Chinovski

+0

@Chinovski,不,在这种情况下。 'q'不应该在这里添加 – RomanPerekhrest

+0

@tripleee,所有扩展的情况都应该在问题中进行描述和阐述。任何人都可以创造越来越多的扩展条件 – RomanPerekhrest

相关问题