用Python读中法卫星CFOSAT轨道资料的时候遇到的时间转换问题
CFOSAT轨道文件中的时间格式
CFOSAT轨道文件是nc格式的,用xarray.open_dataset读取后,它的时间是b’20221115T083925:456’的格式的。
用python转换时间格式
看着很简单,直接用datetime进行转换就行
import datetime
from datetime import timedelta
t = b'20201003T230514:456'
t = t.decode().split(':')[0]
print(t)
tt1 = datetime.datetime.strptime(t.replace('T',''),'%Y%m%d%H%M%S')
print(tt1)
输出结果如下:
出现报错及原因分析
结果上面的转换出现了报错,发现报错出现在时间为b’20201004T006000:456’时。报错内容为:
仔细看一下,这个时间的写法就很奇怪,00时60分00秒为什么不写成01时00分00秒呢?这样更符合使用习惯啊。
也许就是这样的奇怪写法导致了字符串转换为时间戳的时候报错。
解决方法
转换思路:Y年M月D日H时M分S分 = Y月M日00时00分00秒+ H小时+M分钟+S秒
所以,代码如下:
import datetime
from datetime import timedelta
t = b'20201004T006000:456'
t = t.decode().split(':')[0]
print(t)
tt2 = datetime.datetime.strptime(t.split('T')[0],'%Y%m%d')+timedelta(hours =int(t.split('T')[1][0:2]) )+timedelta(minutes =int(t.split('T')[1][2:4]))+timedelta(seconds =int(t.split('T')[1][4:6]) )
print(tt2)
结果如下: