gpt4 book ai didi

文本文件之间的Python日期/时间转换

转载 作者:太空宇宙 更新时间:2023-11-04 01:38:18 26 4
gpt4 key购买 nike

我有一个水文模型文本文件输出 (export.txt),如下所示:

单位 CFS
输入 INST-VAL
1 1997 年 1 月 1 日,02:00 1933.0
2 1997 年 1 月 1 日 04:00 1918.0
3 1997 年 1 月 1 日,06:00 1918.0
1997 年 1 月 4 日 08:00 1904.0
5 1997 年 1 月 1 日,10:00 1904.0
...


并让 Python (2.6) 对以下代码进行编码以格式化输入到优化过程:

import re
o=open("C:\documents and settings\cmjawdy\desktop\PyOut.txt","w")
data=open("C:\documents and settings\cmjawdy\desktop\export.txt").read()
Step1=re.sub(":00",":00:00",data)
Step2=re.sub(" Jan ","/01/",Step1)
Step3=re.sub(",","",Step2)
FindIDs=re.compile("^[0-9]*\s",re.M)
Step4=re.sub(FindIDs,"SiteXXX ",Step3)
o.write(Step4)
o.close()

产量:

单位 CFS
输入 INST-VAL
SiteXXX 01/01/1997 02:00:00 1933.0
SiteXXX 01/01/1997 04:00:00 1918.0
SiteXXX 01/01/1997 06:00:00 1918.0
SiteXXX 01/01/1997 08:00:00 1904.0
SiteXXX 01/01/1997 10:00:00 1904.0
...


问题是我的优化软件不能以24为小时,而必须以00为次日的小时。因此,我需要将第 X 天的 24:00:00 转换为第 X+1 天的 00:00:00,同时保持相同的格式。看起来 strptime/strftime 也不用 24。这些绝对是我学习任何计算机语言的第一行,我找不到一种优雅的方式来转换这些文本。

最佳答案

import datetime
s = '''1 01 Jan 1997, 02:00 1933.0
2 01 Jan 1997, 04:00 1918.0
3 01 Jan 1997, 06:00 1918.0
4 01 Jan 1997, 08:00 1904.0
5 01 Jan 1997, 10:00 1904.0
6 01 Jan 1997, 24:00 1000.0'''
for row in s.split('\n'):
prefix = row[:2]
sdate = row[2:-7]
suffix = row[-7:]
if sdate[13:15] == '24':
offset = datetime.timedelta(1)
sdate = sdate[:13] + '00' + sdate[15:]
else:
offset = datetime.timedelta(0)
dt = datetime.datetime.strptime(sdate, '%d %b %Y, %H:%M') + offset
print prefix + dt.strftime('%d/%m/%Y %H:%M:%S') + suffix

结果:

1 01/01/1997 02:00:00 1933.0
2 01/01/1997 04:00:00 1918.0
3 01/01/1997 06:00:00 1918.0
4 01/01/1997 08:00:00 1904.0
5 01/01/1997 10:00:00 1904.0
6 02/01/1997 00:00:00 1000.0

关于文本文件之间的Python日期/时间转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7638138/

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