2017-02-24 336 views
-3

我在unix中搜索一系列文件,但问题在于我的输入数据是UTC格式我必须将冷杉转换为EST,然后应用过滤器是否有办法在unix awk中?在utx awk中将utc时间戳转换为est

awk '$2FS >="2017-02-21T11:09:41.000Z" && $2FS <="2017-02-23T11:09:41.000Z"' 

有什么一些事情,如下面很简单:

awk 'convert_to_date($2FS,'EST') >="2017-02-21T11:09:41.000Z" 
&& convert_to_date($2FS,'EST') <="2017-02-23T11:09:41.000Z"' 
+0

POSIX awk或gawk? gawk是标准的线路和时间功能。 – dawg

+0

解决了上述问题的任何东西(awk,gawk或perl) –

回答

0

你可以试试下面的bash解决方案 -

猫TIME.TXT

脚本
1 2017-02-22T11:09:41.000Z 
2 2017-02-23T11:09:41.000Z 
3 2017-02-24T11:09:41.000Z 
4 2017-02-25T11:09:41.000Z 
5 2017-02-26T11:09:41.000Z 



    cat ./time.sh 
#!/bin/bash 
d="2017-02-21T11:09:41.000Z" 
b="2017-02-23T11:09:41.000Z" 
USERTIME1=`awk -F'[T]|[-]|[:]|[.]' '{datetime=mktime($1 " "$2 " " $3 " " $4 " " $5 " " $6); print datetime}' <<< $d` 
USERTIME2=`awk -F'[T]|[-]|[:]|[.]' '{datetime=mktime($1 " "$2 " " $3 " " $4 " " $5 " " $6); print datetime}' <<< $b` 
for i in `cat time.txt|awk '{print $2}'` 
do 
var=`awk 'BEGIN{FS="[T]|[-]|[:]|[.]"} {print mktime($1 " "$2 " " $3 " " $4 " " $5 " " $6)}' <<< $i` 
var1=`expr $var - 21600` 
if [ $var1 -ge $USERTIME1 ] && [ $var1 -le $USERTIME2 ] 
then 
echo "$i" 
fi 
done 

输出:

./time.sh 
2017-02-22T11:09:41.000Z 
2017-02-23T11:09:41.000Z 

我试图用awk解决这个问题,但没有成功,如果任何人都可以帮忙。这里是代码 -

### 1:11 AM Friday, Eastern Time (ET) is 
### 6:11 AM Friday, Coordinated Universal Time (UTC) 
### UTC to EST is 6 hour of difference means (-21600) 
BEGIN{FS="[T]|[-]|[:]|[.]";d="2017-02-25T11:09:41.000Z";b="2017-02-23T11:09:41.000Z"} 
{ 
USERTIME1=(substr(d,0,4) " " substr(d,6,2) " "substr(d,9,2) " " substr(d,12,2) " " substr(d,15,2) " "substr(d,18,2) " " substr(d,21,2)) 
USERTIME2=(substr(b,0,4) " " substr(b,6,2) " "substr(b,9,2) " " substr(b,12,2) " " substr(b,15,2) " "substr(b,18,2) " " substr(b,21,2)) 
UTCTIME=($1 " "$2 " " $3 " " $4 " " $5 " " $6) 
ESTTIME=(UTCTIME-21600) 
if((mktime(ESTTIME) >= mktime(USERTIME1)) && mktime((ESTTIME) <= mktime(USERTIME2)) 
print 
} 
+0

我们可以将awk -F应用到管道流,我们可以应用到管道流下面的例子我尝试过但是无法找出它,例如aws s3api list-objects --bucket bucket --prefix文件夹--query'内容[*] [Key,LastModified]' - 输出文本| grep -i filesearch | awk'$ 2FS> =“2017-02-21T11:09:41.000Z”&& $ 2FS <=“2017-02-23T11:09:41.000Z”'| awk'{gsub(“T”,“”,$ 2); GSUB( “Z”, “”,$ 2); GSUB( “ - ”, “”,$ 2); GSUB( “:”, “”,$ 2); GSUB(” 000" , “”,$ 2);打印}'| awk'{a = $ 1; b = $ 2“”$ 3; d = b-21600; c = b;打印a,c,d}' –

相关问题