gpt4 book ai didi

datetime - 将 12 小时日期/时间转换为 24 小时日期/时间

转载 作者:行者123 更新时间:2023-12-02 10:56:42 25 4
gpt4 key购买 nike

我有一个制表符分隔文件,其中每条记录都有一个 12 小时格式的时间戳字段:

mm/dd/yyyy hh:mm:ss [AM|PM].

我需要快速将这些字段转换为 24 小时时间:

mm/dd/yyyy HH:mm:ss.

最好的方法是什么?我在 Windows 平台上运行,但除了常用的 Windows 工具之外,我还可以访问 sed、awk、perl、python 和 tcl。

最佳答案

使用 Perl 和手工制作的正则表达式而不是像 strptime 这样的工具:

#!/bin/perl -w
while (<>)
{
# for date times that don't use leading zeroes, use this regex instead:
# (?:\d{1,2}/\d{1,2}/\d{4} )(\d{1,2})(?::\d\d:\d\d) (AM|PM)
while (m%(?:\d\d/\d\d/\d{4} )(\d\d)(?::\d\d:\d\d) (AM|PM)%)
{
my $hh = $1;
$hh -= 12 if ($2 eq 'AM' && $hh == 12);
$hh += 12 if ($2 eq 'PM' && $hh != 12);
$hh = sprintf "%02d", $hh;
# for date times that don't use leading zeroes, use this regex instead:
# (\d{1,2}/\d{1,2}/\d{4} )(\d{1,2})(:\d\d:\d\d) (?:AM|PM)
s%(\d\d/\d\d/\d{4} )(\d\d)(:\d\d:\d\d) (?:AM|PM)%$1$hh$3%;
}
print;
}

这非常繁琐 - 但每行也可能转换多个时间戳。

请注意,AM/PM 到 24 小时制的转换并非易事。

  • 上午 12:01 --> 00:01
  • 下午 12:01 --> 12:01
  • 上午 01:30 --> 01:30
  • 下午 1:30 --> 13:30

现已测试:

perl ampm-24hr.pl <<!
12/24/2005 12:01:00 AM
09/22/1999 12:00:00 PM
12/12/2005 01:15:00 PM
01/01/2009 01:56:45 AM
12/30/2009 10:00:00 PM
12/30/2009 10:00:00 AM
!

12/24/2005 00:01:00
09/22/1999 12:00:00
12/12/2005 13:15:00
01/01/2009 01:56:45
12/30/2009 22:00:00
12/30/2009 10:00:00
<小时/>

已添加:

What is a Simple Way to Convert Between an AM/PM Time and 24 hour Time in JavaScript ,提供了另一种转换算法:

$hh = ($1 % 12) + (($2 eq 'AM') ? 0 : 12);

只需一个测试...可能更简洁。

关于datetime - 将 12 小时日期/时间转换为 24 小时日期/时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/440061/

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