generated from mwc/lab_weather
40 lines
1.4 KiB
Python
40 lines
1.4 KiB
Python
# weather.py
|
|
# ------------
|
|
# By MWC Contributors
|
|
#
|
|
# Defines `print_weather`, which does all the work of fetching
|
|
# the requested weather data and printing it out to the screen
|
|
# in a sensible way.
|
|
#
|
|
# It's your job to implement this function.
|
|
|
|
from weather_apis import (
|
|
geocode_location,
|
|
estimate_location,
|
|
get_weather_office,
|
|
get_forecast
|
|
)
|
|
|
|
def print_weather(location=None, metric=False, verbose=False):
|
|
"""Prints out a weather report using the provided location, or using
|
|
the user's current location if no location was provided.
|
|
When metric is True, prints out the weather in metric units.
|
|
When verbose is True, prints out a more detailed report.
|
|
"""
|
|
if location == None:
|
|
coordinates = estimate_location()
|
|
else:
|
|
coordinates = geocode_location(location)
|
|
|
|
office_info = get_weather_office(coordinates["lat"], coordinates["lng"])
|
|
office_only = office_info["office"]
|
|
|
|
all_forecasts = get_forecast(office_info["office"], office_info["x"], office_info["y"])
|
|
print(all_forecasts)
|
|
print()
|
|
print("The forecast for", office_only, "is")
|
|
for forecast in all_forecasts:
|
|
print(forecast["name"],"temperature of", forecast["temperature"], "wind speed of", forecast["wind_speed"], "out of the ", forecast["wind_direction"],"conditions of", forecast["description"]) # YOUR CODE HERE!
|
|
print()
|
|
|
|
print_weather() |