1. 引入相关库
import datetime
from timezonefinder import TimezoneFinder
import pandas as pd
2. 函数(参数为年月日时分秒、经度、纬度)
2.1 获取经纬度对应的时区
tf = TimezoneFinder(in_memory=True) # 将相应的时区信息读入内存中
time_zone = tf.timezone_at(lng=lon, lat=lat) # 得到对应的时区(经度,纬度)
输出结果(以-30°,70°为例):
2.2 获取时间序列
utc_time = datetime.datetime(year, month, day, hour, minute, second)
utc_time_str = utc_time.strftime('%Y-%m-%d %H:%M:%S') # 获取时间字符串
test_naive = pd.date_range(utc_time_str, utc_time_str) # 获取时间序列(开始结束时间一致)
2.3 建立UTC时并将UTC时转化为LT时
test_UTC = test_naive.tz_localize('UTC') # 建立UTC时
test_local = test_UTC.tz_convert(time_zone) # UTC转化成LT时
2.4 删除时区信息
这里有时区信息,所以需要把时区信息删掉:
test_local_naive = test_local.tz_localize(None) # 去掉对应时区信息格式
2.5 输出
str1 = test_local_naive[0].strftime("%Y-%m-%d %H:%M:%S") # 将时间戳转为字符串
LT_time = datetime.datetime.strptime(str1, "%Y-%m-%d %H:%M:%S") # 转为datetime格式
print(LT_time)
3.调用函数
UTC_to_LT(2009, 5, 16, 23, 25, 58, -30, 70)