generated from mwc/lab_weather
41 lines
1.2 KiB
Python
41 lines
1.2 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.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:
|
|
coordinates = geocode_location(location)
|
|
else:
|
|
coordinates = estimate_location()
|
|
|
|
office = get_weather_office(coordinates["lat"], coordinates["lng"])
|
|
|
|
forecast = get_forecast(office["office"], office["x"], office["y"], metric=metric)
|
|
#print(forecast) # YOUR CODE HERE!
|
|
for day in forecast:
|
|
display = day["name"] +":"+ day["description"] + " with a high of " + str(day["temperature"]) + "."
|
|
print(display)
|
|
|
|
|
|
|
|
|
|
|