繁体   English   中英

如何将UTC和经度转换为平均太阳当地时间python

[英]How to convert UTC and longitude to mean solar local time python

我正在尝试将我的UTC时间和经度转换为python中的平均太阳当地时间。

输入:

utc = ['2000-08-20 07:15:12.000']  #utc time

lon = [-89.91054415]               #longitude

我用astropy.time来获取我的utc时间,它是一个字符串。

我在这里找到了使用pyephem的解决方案。 如果要考虑的话,它确实考虑了夏令时。

from ephem import Sun, Observer, pi, hours

dt = '2016/08/27 19:19'

sun = Sun()
sun.compute(dt)

boston = Observer()
boston.lat = '42.37'
boston.lon = '-71.03'
boston.date = dt
ra, dec = boston.radec_of('0', '-90')

print 'Sun right ascension:', sun.ra
print 'Boston nadir right ascension:', ra
print 'Solar time:', hours((ra - sun.ra) % (2 * pi)), 'hours'

天文年鉴第3版的说明性补编 第239页指出,当地平均太阳时间LMSoT与UT和观测者的东经有关

LMSoT = UT +ƛ

UT通常是指UT1。 要将UTC转换为UT1,请参阅公告A, 网址https://www.iers.org/IERS/EN/DataProducts/EarthOrientationData/eop.html

对于2016/08/27 UT1-UTC = -0.243031。 原始海报仅工作到毫秒,因此四舍五入为-0.243。 2016/08/27 19:19:00.000 UTC = 19:18:59.757 UT1。

波士顿纬度-71.03°,转换为时间,= -4 h 44 m 7.200 s

波士顿LMSoT = 19:18:59.757-4:44:7.2000 = 14:34:52.557

原始海报可以根据所需的实际精度来简化过程。 特别是,UTC始终在UT1的0.9 s之内,因此,如果不需要精确到秒,则可以跳过查找UT1-UTC的步骤。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM