gpt4 book ai didi

linux - 使用 awk/sed 更改第一列中的日期格式

转载 作者:IT王子 更新时间:2023-10-29 01:02:15 24 4
gpt4 key购买 nike

我有一个每天早上自动运行的 shell 脚本,它将当天的结果附加到一个文本文件中。该文件的第一列应该是今天的日期,后面是用逗号分隔的结果。我使用命令 date +%x 以所需格式 (dd/mm/yy) 获取日期。但是在一台计算机上 date +%x 返回 mm/dd/yyyy(知道为什么会这样吗?)。然后,我按日期顺序对文件中的数据进行排序。

这是一个这样的文本文件的片段

29/11/12,9654.80,194.32,2.01,7.19,-7.89,7.65,7.57,3.98,9625.27,160.10,1.66,4.90,-4.79,6.83,4.84,3.54                
03/12/12,5184.22,104.63,2.02,6.88,-6.49,7.87,6.67,4.10,5169.52,93.81,1.81,5.29,-5.45,7.87,5.37,4.10
04/12/12,5183.65,103.18,1.99,6.49,-6.80,8.40,6.66,4.38,5166.04,95.44,1.85,6.04,-6.49,8.40,6.28,4.38
11/07/2012,5183.65,102.15,1.97,6.78,-6.36,8.92,6.56,4.67,5169.48,96.67,1.87,5.56,-6.10,8.92,5.85,4.67
07/11/2012,5179.39,115.57,2.23,7.64,-6.61,8.83,7.09,4.62,5150.17,103.52,2.01,7.01,-6.08,8.16,6.51,4.26
11/26/2012,5182.66,103.30,1.99,7.07,-5.76,7.38,6.37,3.83,5162.81,95.47,1.85,6.34,-5.40,6.65,5.84,3.44
11/30/2012,5180.82,95.19,1.84,6.51,-5.40,7.91,5.92,4.12,5163.98,91.82,1.78,5.58,-5.07,7.05,5.31,3.65

是否可以使用 awk 或 sed 将后四行的日期格式更改为正确的日期格式?我只想将 mm/dd/yyyy 格式的日期格式更改为 dd/mm/yy。

最佳答案

看起来您正在使用两种不同风格(版本)的 date。要检查你有哪些版本,我认为 GNU date 接受 --version 标志,而其他版本,如 BSD/OSX 则不会接受这个标志。

由于您可能使用完全不同的系统,完全避免使用 date 并使用 perl 打印当前日期可能是最安全的:

perl -MPOSIX -e 'print POSIX::strftime("%d/%m/%y", localtime) . "\n"'

如果你确定你在两台机器上都有 GNU awk,你可以像这样使用它:

awk 'BEGIN { print strftime("%d/%m/%y") }'

要修复您的文件,这是我使用 GNU awk 的做法:

awk '{ print gensub(/^(..\/)(..\/)..(..,)/, "\\2\\1\\3", "g"); next }1' file

或者使用sed:

sed 's/^\(..\/\)\(..\/\)..\(..,\)/\2\1\3/' file

结果:

29/11/12,9654.80,194.32,2.01,7.19,-7.89,7.65,7.57,3.98,9625.27,160.10,1.66,4.90,-4.79,6.83,4.84,3.54                
03/12/12,5184.22,104.63,2.02,6.88,-6.49,7.87,6.67,4.10,5169.52,93.81,1.81,5.29,-5.45,7.87,5.37,4.10
04/12/12,5183.65,103.18,1.99,6.49,-6.80,8.40,6.66,4.38,5166.04,95.44,1.85,6.04,-6.49,8.40,6.28,4.38
07/11/12,5183.65,102.15,1.97,6.78,-6.36,8.92,6.56,4.67,5169.48,96.67,1.87,5.56,-6.10,8.92,5.85,4.67
11/07/12,5179.39,115.57,2.23,7.64,-6.61,8.83,7.09,4.62,5150.17,103.52,2.01,7.01,-6.08,8.16,6.51,4.26
26/11/12,5182.66,103.30,1.99,7.07,-5.76,7.38,6.37,3.83,5162.81,95.47,1.85,6.34,-5.40,6.65,5.84,3.44
30/11/12,5180.82,95.19,1.84,6.51,-5.40,7.91,5.92,4.12,5163.98,91.82,1.78,5.58,-5.07,7.05,5.31,3.65

关于linux - 使用 awk/sed 更改第一列中的日期格式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13702824/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com