在下面的awk中,I echo f是空的,但是如果删除$f,就会得到所需的结果,但是新格式不会存储在$d变量中。基本上,我试图将$d变量中的字符串转换为一个新的格式化变量$f。谢谢:)。
文件
ID,1A
DATE,220102awk
d=$(awk -F, '/Date/ {print $2}' file) | f=$(date -d "$d" +'%Y-%m-%d')f --理想的
2022-01-02发布于 2022-09-21 21:35:49
您需要使用它从awk返回一个值,并设置一个shell变量:
f=$(date -d "$(awk -F, '/DATE/ {print $2}' file)" +'%Y-%m-%d')
echo "$f"
2022-01-02发布于 2022-09-22 04:40:44
在显示的示例中,请尝试遵循awk代码。用GNU awk编写和测试。使用awk的match函数功能,使用regex ^DATE,([0-9]{2})([0-9]{2})([0-9]{2})$获得所需的输出。这将创建3个捕获组,并在匹配完成后将匹配值存储到名为arr的数组中,然后根据需要的输出打印20和由-分隔的所有3个数组值。
awk -v OFS="-" '
match($0,/^DATE,([0-9]{2})([0-9]{2})([0-9]{2})$/,arr){
  print "20" arr[1],arr[2],arr[3]
}
'  Input_file发布于 2022-09-21 21:59:03
虽然其他答案提供了一种更有效的方法来重新格式化日期(假设OP在后续代码中不需要d ),但我将只关注OP当前代码的几个问题:
awk脚本中,需要匹配(所有大写) DATE而不是Dated=$(...)输送到代码的f=$(...)部分;虽然这是“工作”的,因为f将被分配给2022-01-02,但问题是,分配给f的任务是在子进程中执行的,并且在退出子进程f时实际上是“未分配”的;OP真正需要的是将d=$(...)和f=$(...)命令相互分离,以便两个分配都发生在当前的shell中,这可以通过用分号替换管道来完成。如果我们做这两个简单的编辑:
# old code:
d=$(awk -F, '/Date/ {print $2}' file) | f=$(date -d "$d" +'%Y-%m-%d')
              ^^^^                   ^^^
# new code:
d=$(awk -F, '/DATE/ {print $2}' file) ; f=$(date -d "$d" +'%Y-%m-%d')
              ^^^^                   ^^^OP的代码现在将生成所需的结果:
$ echo "${f}"
2022-01-02https://stackoverflow.com/questions/73807151
复制相似问题