gpt4 book ai didi

python - ISO 8601 日期时间格式 : parse 11:05:14 PM into 23:05:14

转载 作者:行者123 更新时间:2023-11-30 23:03:37 24 4
gpt4 key购买 nike

我目前正在获取 ISO 格式,但我不确定如何获取 ISO (8601) 格式。

当我将以下日期 08/10/2015 11:05:14 PM 转换为 ISO 格式时,我得到 2015-08-10T11:05:14+0000

理想情况下我应该得到 2015-08-10T23:05:14+0000

将日期编辑为 iso 格式的行是:

new[3] = datetime.strptime(new[3], "%m/%d/%Y %H:%M:%S %p").isoformat() + '+0000'

代码:

from tempfile import NamedTemporaryFile
from datetime import datetime
from shutil import move
from operator import itemgetter
import csv
from pathlib import Path


def change_file(in_file, cols):
with open(in_file) as f, NamedTemporaryFile("w", dir=".", delete=False) as tmp:
r = csv.reader(f)
wr = csv.writer(tmp)
count = 0
for row in r:
if count == 0:
new = []
for x in itemgetter(*cols)(row):
new.append(x.lstrip())
wr.writerow(new)
count += 1
continue
if row != '\n':
new = []
print(row)

for x in itemgetter(*cols)(row):
new.append(x.lstrip())
new[3] = datetime.strptime(new[3], "%m/%d/%Y %H:%M:%S %p").isoformat() + '+0000'
print(new)
wr.writerow(new)
move(tmp.name, in_file)

for fle in Path('./BM').glob('**/*/cplt.csv'):
print(fle)
change_file(str(fle), (6, 2, 1, 0, 5))

最佳答案

输入格式到底如何?

当我将格式字符串更改为 %m/%d/%y %H:%M:%S 时,出现以下内容

print datetime.strptime('08/10/15 23:05:14', '%m/%d/%y %H:%M:%S').isoformat() + '+0000'

给出正确的结果:

2015-08-10T23:05:14+0000

编辑

感谢您提供的附加信息,如果您只需将 %H 替换为 %I 就可以了:

 print datetime.strptime('8/10/2015 11:05:14 PM', '%m/%d/%Y %I:%M:%S %p').isoformat() + '+0000'

来自datetime docs :

%I - Hour (12-hour clock) as a zero-padded decimal number.

只有 %I 才会考虑 am/pm 部分。

关于python - ISO 8601 日期时间格式 : parse 11:05:14 PM into 23:05:14,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34020404/

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