mirror of
https://github.com/chubin/wttr.in
synced 2025-01-12 03:58:45 +00:00
v2: fixed bug with location behind polar circle
This commit is contained in:
parent
a0798d3482
commit
d7afd94c31
2 changed files with 67 additions and 28 deletions
|
@ -34,8 +34,7 @@ import pyjq
|
||||||
import pytz
|
import pytz
|
||||||
import numpy as np
|
import numpy as np
|
||||||
from astral import LocationInfo
|
from astral import LocationInfo
|
||||||
from astral import moon
|
from astral import moon, sun
|
||||||
from astral.sun import sun
|
|
||||||
from scipy.interpolate import interp1d
|
from scipy.interpolate import interp1d
|
||||||
from babel.dates import format_datetime
|
from babel.dates import format_datetime
|
||||||
|
|
||||||
|
@ -255,35 +254,54 @@ def draw_astronomical(city_name, geo_data):
|
||||||
current_date = (
|
current_date = (
|
||||||
datetime_day_start
|
datetime_day_start
|
||||||
+ datetime.timedelta(hours=1*time_interval)).replace(tzinfo=pytz.timezone(geo_data["timezone"]))
|
+ datetime.timedelta(hours=1*time_interval)).replace(tzinfo=pytz.timezone(geo_data["timezone"]))
|
||||||
current_sun = sun(city.observer, date=current_date)
|
|
||||||
|
|
||||||
dawn = current_sun['dawn'] # .replace(tzinfo=None)
|
try:
|
||||||
dusk = current_sun['dusk'] # .replace(tzinfo=None)
|
dawn = sun.dawn(city.observer, date=current_date)
|
||||||
sunrise = current_sun['sunrise'] # .replace(tzinfo=None)
|
except ValueError:
|
||||||
sunset = current_sun['sunset'] # .replace(tzinfo=None)
|
dawn = current_date
|
||||||
|
|
||||||
|
try:
|
||||||
|
dusk = sun.dusk(city.observer, date=current_date)
|
||||||
|
except ValueError:
|
||||||
|
dusk = current_date + datetime.timedelta(hours=24)
|
||||||
|
|
||||||
|
try:
|
||||||
|
sunrise = sun.sunrise(city.observer, date=current_date)
|
||||||
|
except ValueError:
|
||||||
|
sunrise = current_date
|
||||||
|
|
||||||
|
try:
|
||||||
|
sunset = sun.sunset(city.observer, date=current_date)
|
||||||
|
except ValueError:
|
||||||
|
sunset = current_date + datetime.timedelta(hours=24)
|
||||||
|
|
||||||
|
char = "."
|
||||||
if current_date < dawn:
|
if current_date < dawn:
|
||||||
char = " "
|
char = " "
|
||||||
elif current_date > dusk:
|
elif current_date > dusk:
|
||||||
char = " "
|
char = " "
|
||||||
elif dawn < current_date and current_date < sunrise:
|
elif dawn <= current_date and current_date <= sunrise:
|
||||||
char = u"─"
|
char = u"─"
|
||||||
elif sunset < current_date and current_date < dusk:
|
elif sunset <= current_date and current_date <= dusk:
|
||||||
char = u"─"
|
char = u"─"
|
||||||
elif sunrise < current_date and current_date < sunset:
|
elif sunrise <= current_date and current_date <= sunset:
|
||||||
char = u"━"
|
char = u"━"
|
||||||
|
|
||||||
answer += char
|
answer += char
|
||||||
|
|
||||||
# moon
|
# moon
|
||||||
if time_interval % 3 == 0:
|
if time_interval in [0,23,47,69]: # time_interval % 3 == 0:
|
||||||
moon_phase = moon.phase(
|
moon_phase = moon.phase(
|
||||||
date=datetime_day_start + datetime.timedelta(hours=time_interval))
|
date=datetime_day_start + datetime.timedelta(hours=time_interval))
|
||||||
moon_phase_emoji = constants.MOON_PHASES[int(math.floor(moon_phase*1.0/28.0*8+0.5)) % len(constants.MOON_PHASES)]
|
moon_phase_emoji = constants.MOON_PHASES[
|
||||||
if time_interval in [0, 24, 48, 69]:
|
int(math.floor(moon_phase*1.0/28.0*8+0.5)) % len(constants.MOON_PHASES)]
|
||||||
moon_line += moon_phase_emoji + " "
|
# if time_interval in [0, 24, 48, 69]:
|
||||||
else:
|
moon_line += moon_phase_emoji # + " "
|
||||||
|
elif time_interval % 3 == 0:
|
||||||
|
if time_interval not in [24,28]: #se:
|
||||||
moon_line += " "
|
moon_line += " "
|
||||||
|
else:
|
||||||
|
moon_line += " "
|
||||||
|
|
||||||
|
|
||||||
answer = moon_line + "\n" + answer + "\n"
|
answer = moon_line + "\n" + answer + "\n"
|
||||||
|
@ -465,7 +483,6 @@ def textual_information(data_parsed, geo_data, config, html_output=False):
|
||||||
|
|
||||||
datetime_day_start = datetime.datetime.now()\
|
datetime_day_start = datetime.datetime.now()\
|
||||||
.replace(hour=0, minute=0, second=0, microsecond=0)
|
.replace(hour=0, minute=0, second=0, microsecond=0)
|
||||||
current_sun = sun(city.observer, date=datetime_day_start)
|
|
||||||
|
|
||||||
format_line = "%c %C, %t, %h, %w, %P"
|
format_line = "%c %C, %t, %h, %w, %P"
|
||||||
current_condition = data_parsed['data']['current_condition'][0]
|
current_condition = data_parsed['data']['current_condition'][0]
|
||||||
|
@ -477,18 +494,37 @@ def textual_information(data_parsed, geo_data, config, html_output=False):
|
||||||
|
|
||||||
local_tz = pytz.timezone(timezone)
|
local_tz = pytz.timezone(timezone)
|
||||||
|
|
||||||
local_time_of = lambda x: current_sun[x]\
|
def _get_local_time_of(what):
|
||||||
.replace(tzinfo=pytz.utc)\
|
_sun = {
|
||||||
.astimezone(local_tz)\
|
"dawn": sun.dawn,
|
||||||
.strftime("%H:%M:%S")
|
"sunrise": sun.sunrise,
|
||||||
|
"noon": sun.noon,
|
||||||
|
"sunset": sun.sunset,
|
||||||
|
"dusk": sun.dusk,
|
||||||
|
}[what]
|
||||||
|
|
||||||
|
current_time_of_what = _sun(city.observer, date=datetime_day_start)
|
||||||
|
return current_time_of_what\
|
||||||
|
.replace(tzinfo=pytz.utc)\
|
||||||
|
.astimezone(local_tz)\
|
||||||
|
.strftime("%H:%M:%S")
|
||||||
|
|
||||||
|
local_time_of = {}
|
||||||
|
for what in ["dawn", "sunrise", "noon", "sunset", "dusk"]:
|
||||||
|
try:
|
||||||
|
local_time_of[what] = _get_local_time_of(what)
|
||||||
|
except ValueError:
|
||||||
|
local_time_of[what] = "-"*8
|
||||||
|
|
||||||
tmp_output = []
|
tmp_output = []
|
||||||
|
|
||||||
tmp_output.append(' Now: %%{{NOW(%s)}}' % timezone)
|
tmp_output.append(' Now: %%{{NOW(%s)}}' % timezone)
|
||||||
tmp_output.append('Dawn: %s' % local_time_of("dawn"))
|
tmp_output.append('Dawn: %s' % local_time_of["dawn"])
|
||||||
tmp_output.append('Sunrise: %s' % local_time_of("sunrise"))
|
tmp_output.append('Sunrise: %s' % local_time_of["sunrise"])
|
||||||
tmp_output.append(' Zenith: %s ' % local_time_of("noon"))
|
tmp_output.append(' Zenith: %s ' % local_time_of["noon"])
|
||||||
tmp_output.append('Sunset: %s' % local_time_of("sunset"))
|
tmp_output.append('Sunset: %s' % local_time_of["sunset"])
|
||||||
tmp_output.append('Dusk: %s' % local_time_of("dusk"))
|
tmp_output.append('Dusk: %s' % local_time_of["dusk"])
|
||||||
|
|
||||||
tmp_output = [
|
tmp_output = [
|
||||||
re.sub("^([A-Za-z]*:)", lambda m: _colorize(m.group(1), "2"), x)
|
re.sub("^([A-Za-z]*:)", lambda m: _colorize(m.group(1), "2"), x)
|
||||||
for x in tmp_output]
|
for x in tmp_output]
|
||||||
|
|
|
@ -27,12 +27,15 @@ def get_wetter(parsed_query):
|
||||||
if location == NOT_FOUND_LOCATION:
|
if location == NOT_FOUND_LOCATION:
|
||||||
location_not_found = True
|
location_not_found = True
|
||||||
|
|
||||||
|
stderr = ""
|
||||||
|
returncode = 0
|
||||||
if not location_not_found:
|
if not location_not_found:
|
||||||
stdout, stderr, returncode = _wego_wrapper(location, parsed_query)
|
stdout, stderr, returncode = _wego_wrapper(location, parsed_query)
|
||||||
|
|
||||||
if location_not_found or returncode != 0:
|
if location_not_found or \
|
||||||
if ('Unable to find any matching weather'
|
(returncode != 0 \
|
||||||
' location to the parsed_query submitted') in stderr:
|
and ('Unable to find any matching weather'
|
||||||
|
' location to the parsed_query submitted') in stderr):
|
||||||
stdout, stderr, returncode = _wego_wrapper(NOT_FOUND_LOCATION, parsed_query)
|
stdout, stderr, returncode = _wego_wrapper(NOT_FOUND_LOCATION, parsed_query)
|
||||||
location_not_found = True
|
location_not_found = True
|
||||||
stdout += get_message('NOT_FOUND_MESSAGE', lang)
|
stdout += get_message('NOT_FOUND_MESSAGE', lang)
|
||||||
|
|
Loading…
Reference in a new issue