我有一个shell脚本,该脚本每天早晨自动运行,将当天的结果附加到文本文件中。该文件的第一列应为今天的日期,然后是结果,以逗号分隔。我使用命令date +%x以所需的格式(dd / mm / yy)获取日期。但是,在一台计算机上,+%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
Run Code Online (Sandbox Code Playgroud)
是否可以使用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"'
Run Code Online (Sandbox Code Playgroud)
如果确定GNU awk
在两台计算机上都使用过,则可以这样使用:
awk 'BEGIN { print strftime("%d/%m/%y") }'
Run Code Online (Sandbox Code Playgroud)
要修复您拥有的文件,这是我的使用GNU awk
:
awk '{ print gensub(/^(..\/)(..\/)..(..,)/, "\\2\\1\\3", "g"); next }1' file
Run Code Online (Sandbox Code Playgroud)
或使用sed
:
sed 's/^\(..\/\)\(..\/\)..\(..,\)/\2\1\3/' file
Run Code Online (Sandbox Code Playgroud)
结果:
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
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
6339 次 |
最近记录: |