Я пишу программу на Python, которая должна определить, наступает он после восхода солнца или нет, учитывая только текущее время в формате UTC, а также целевую широту и долготу. Я постоянно вижу, как приложения делают такие вещи, но я понятия не имею, как это делается. Любые идеи?
Учитывая широту и долготу, как я могу определить дневной свет?
Ответы (4)
Вот чья-то реализация расчета восхода / захода солнца в Python: http://michelanders.blogspot.com/2010/12/calulating-sunrise-and-sunset-in-python.html
Полная схема алгоритма находится здесь
На самом деле особо нечего добавить. 10 пунктов в процитированном документе разбивают его на простые для воспроизведения шаги, которые действительно могут быть реализованы на любом языке.
Просто сделав быстрый поиск в Google, я нашел это. Расчеты в NOAA Калькуляторы восхода / захода солнца и положения Солнца основаны на уравнениях из астрономических алгоритмов Жана Миуса. Было подтверждено, что результаты восхода и захода солнца являются точными с точностью до минуты для местоположений между +/- 72 ° широты и в пределах 10 минут за пределами этих широт.
Подробное объяснение деталей расчета можно найти на этой странице, а также здесь. а>
Вам нужно что-то, что просто работает ™? Используйте превосходный язык. И ты знаешь, что это всегда сработает. Как можно доверять 122 направлениям передовой астрофизики? Вы не можете. Но вы всегда можете доверять PHP.
>>> def is_day(lat, lon): # optinally adjust zenith (currently 96) at the end of the line
... return subprocess.check_output(["php","-r","""date_default_timezone_set("GMT");\n$a=date_sunrise(time(),SUNFUNCS_RET_DOUBLE,{0},{1},{2},0);\n$b=date_sunset(time(),SUNFUNCS_RET_DOUBLE,{0},{1},{2},0);\n$t=date("H")+date("i")/60+date("s")/3600;\necho($a<$b?($t>$a&&$t<$b):($t>$a||$t<$b))?"day":"night";""".format(lat,lon,96)])=="day"
... # ^^ optionally adjust zenith here
...
>>> is_day(-33,151) # Sydney
True
>>> is_day(0,0) # Some hundred km off the coast of Africa
False
>>> __import__("datetime").datetime.utcnow()
datetime.datetime(2012, 2, 10, 22, 29, 30, 365019)
>>>