我正在尝试使用awk格式化文件中的某些文本。
要求是用表示人格可读时间的格式化字符串替换表示纪元时间的冒号分隔文件(:)的第3个字段,格式如下: DD / MM / YYYY
以下是一个示例文件:
abc:$3$wHe$JKAP1Ry.CAcEGhD0J7SGVl.AMg.0:1427135400:0:120:7:30::
rst:$6$3WWbfvblr6FF92R5/n3mLdlSkARgfRm1:1427293800:0:40:7:30::
xyz:$1$xuTkkle203F$df.ixcn/mcuFIO90lndn:1420478400:0:90:7:30::
def:$4$vid2003mDEOF$dc2.Rkdlkfdiw8/cib6:1389547200:0:120:7:30::
ab:*$5P1wHeEG$JKA2ya.ikol30.de/ldiv.230:1449771300:0:120:7:30::
xy:$1k3lc930vs.lskdie/sldiemDIIsdk193n:1429995693:0:50:7:30::
xyy:*$tkwsMt972w.Csrl5jr.23nsoijsleqJK:1429995889:0:120:7:30::
通过使用日期将第3个字段中的一个值复制并粘贴到命令中,我已经能够创建所需的结果:
date -d @1427135400 +"%d/%m/%Y"
23/03/2015
这是我试图在脚本中执行的awk命令,我一直在推文脚本,希望能让它工作,但没有运气。 请注意,$ userFound已经存储了上面列出的文件中的一行:
echo $userFound | awk -F':' '{
if ( $2 ~ /^\*/ ) {$2="L"} \
if ($2 ~ /^[^*]/) {$2="P"} \
cmd="date -d @"$3" +\"%d/%m/%Y\"" \
cmd | getline time \
close(cmd) \
} \
END { \
print $1":"$2":"time":"$4":"$5":"$6":"$7":"$8":"$9 \
}'
运行当前脚本,我得到以下输出:
awk: cmd. line:5: (FILENAME=- FNR=1) fatal: expression for `|' redirection has null string value
答案 0 :(得分:5)
答案 1 :(得分:2)
如果你真的需要使用date
(因为你没有GNU awk),你的脚本会进行一些更改,即print语句不应该在END块中。
BEGIN {
FS = ":"
OFS = ":"
}
{
if ( $2 ~ /^\*/ ) {$2="L"}
if ($2 ~ /^[^*]/) {$2="P"}
cmd="date -d @" $3 " +\"%d/%m/%Y\""
cmd | getline time
close(cmd)
print $1, $2, time, $4, $5, $6, $7, $8, $9
}
如果将此脚本放在名为a.awk的文件中,则可以执行
awk -f a.awk foo.txt
如果foo.txt看起来像这样:
abc:$3$wHe$JKAP1Ry.CAcEGhD0J7SGVl.AMg.0:1427135400:0:120:7:30::
rst:$6$3WWbfvblr6FF92R5/n3mLdlSkARgfRm1:1427293800:0:40:7:30::
xyz:$1$xuTkkle203F$df.ixcn/mcuFIO90lndn:1420478400:0:90:7:30::
def:$4$vid2003mDEOF$dc2.Rkdlkfdiw8/cib6:1389547200:0:120:7:30::
ab:*$5P1wHeEG$JKA2ya.ikol30.de/ldiv.230:1449771300:0:120:7:30::
xy:$1k3lc930vs.lskdie/sldiemDIIsdk193n:1429995693:0:50:7:30::
xyy:*$tkwsMt972w.Csrl5jr.23nsoijsleqJK:1429995889:0:120:7:30::
然后这是输出:
abc:P:23/03/2015:0:120:7:30::
rst:P:25/03/2015:0:40:7:30::
xyz:P:05/01/2015:0:90:7:30::
def:P:12/01/2014:0:120:7:30::
ab:P:10/12/2015:0:120:7:30::
xy:P:25/04/2015:0:50:7:30::
xyy:P:25/04/2015:0:120:7:30::