A CLI weather-tool / (app) which fetches a lat/lon coordinates of user-input address (postal codes, zip codes, cities, etc.), from the Google maps API, and uses those coordinates to fetch the past, current, and forecasted weather data from the forecast.io (darksky.net) API (requires an API-key). Currently, this only functions as a CLI (command-line-interface) tool, where functionality is run by Node.js
(e.g. $node app.js -a [address]
) based on the user-input address.
The goal of this project is to ultimately use React.js
to create the font-end of an on-line app where current, hourly, and minutely weather data will be displayed, both visually as time-series figures and as data tables, depending on the input-address from the user. Visual representation will be presented by using D3.js
; Back-end will be powered by Node.js
(currently, to test out and learn the D3.js
library, the back-end server will be powered by Python
); Data fetching, parsing, and manipulations will be done so using Python/Pandas
.
1. Command-Line-Tool (written in JavaScript
)
The CLI tool is a quick way of fetching the current weather conditions from the DarkSky API. Simply call the app.js
script via. node
and the -a
flag to specify a specific address (either a city's name - i.e. Vancouver, or a postal/zip code, or even a country's name) to output the current weather conditions for the specified address.
- Fetching the current weather by a city's name.
- Fetching the current weather by a city's zip-code
- Fetching the current weather by a country's name
2. Web-App (work-in-progress; written in Python/D3.js
)
The web-app is still a work-in-progress, but from the current code there is a currently functional MVP with the current code-base.
Currently, there are two parts to the MVP. Firstly, weather.py
is run, to fetch the weather data from the DarkSky API. Second, when all the data has been fetched, parsed, and saved, the Flask server passes the data to the static html files that renders the data using D3
.
1. Revise the D3
code to be more modular → complete
- Also, research and fix the D3
to render the temperature data returned from both the forecast and time-machine requests. → complete (the problem was the x/y-axis min/max limits between the two data sets being used, I think...)
-
The
D3
rendered figure for the/hindcast
end-point is missing both the y-axis and x-axis bars.- First, this issue needs to be resolved. → complete
-
Then, the multi-line (time-machine & forecast requests)
D3
rendered figure will have to be resolved. complete! (note the original goal of the project was to produce a time series figure showing both the historical and forecasted temperature data).
2. Refactor the flask_server.py
script such that all the data fetching/parsing will be done with requests to particular end-points. complete
3. Start constructing the front-end - Update: - The Landing Page has now been created and can be seen in the image below. -
- __Update__:
- The idea is to have a single __*Landing Page*__ which will have links to *different weather parameters that will be rendered by `D3`.
- The *Landing Page* will have a __search bar__, which will ta`p into Google Maps' API to auto complete the search when given a query for a city's name (e.g. *Vancouver B.C., Canada*).
- With the city's name in hand, a call will be made to the Google Maps API to fetch the lat/lon coordinates of that location.
- Given the location, a request can then be routed to the DarkSky API to retrieve the *hourly* weather data for said location.
- I'd like to construct data-panels which allows the client to view weather time-series' for a variety of weather parameters, etc.
- There is also the possibility of doing the above using `React.js`.
- ...either way, this third step will involve lots more planning and research.
- URL:
https://api.darksky.net/forecast/[key]/[latitude],[longitude]
- returns the current weather conditions, a minute-by-minute forecast for the next hour (where available), an hour-by-hour forecast for the next 48 hours, and a day-by-day forecast for the next week.
- URL:
https://api.darksky.net/forecast/[api-key]/[latitude],[longitude],[time]
- Request returns the observed or forecast weather conditions for a date in the past or future (FOR THE SAKE OF THIS MVP --> FOCUS ON DATES IN THE PAST).
- To run the Flask server,
cd
intopython/flask-d3/
from the projects' root directory. - Once there, run
python flask_server.py
to start the server (onlocalhost::8080
) - End-points,
/
: Index/home page (renderingtemplates/index.html
)- The
/
end-point currently renders an<ul>
element, listinghref
links for different parts of the project- For example, a listing of temperature parameters links directly to the D3 chart of that weather parameter (i.e. clicking on
Temperature
will take you to a statichtml
page for the D3)
- For example, a listing of temperature parameters links directly to the D3 chart of that weather parameter (i.e. clicking on
- The
/about
: Gives a summary of what the project is all about (i.e. what tech stack is used, what API is being used, etc.)/temperature
: Renders the temperature data for both the forecast and time-machine requests to the DarkSky API. Currently, there are some problems encoutered with this end-point (refer to the question posted on stackoverflow), which I'm currently attempting to solve./forecast
: Renders the staticD3
HTML
page, producing a figure of the temperature data returned from a forecast request to the DarkSky API.
- Work-in-progress
- My progress on learning how to implement
D3.js
can be viewed on as an Observable notebook. - The goal is to generate a figure like the one below, but using
D3.js
instead of matplotlib.
- The figure above displays the hourly temperature data for both forecast and time-machine requests to the Dark Sky API.
- For the two data-series' plotted above, there is an obvious region of overlap between the hindcast and forecast hourly temperature data returned, from the two API requests.
- The time machine request above, was made for April 3, 2018, which means hourly temperatures from 03 Apr 00:00 to 03 Apr 23:00 are returned.
- The forecast request was made @ ~ 14:00 today (April 3), which means there will be an overlap of > 7 hours.
- This can be countered by either a. cutting a slice of the data from the forecast data series, or b. cutting a slice of the time-machine data series... (more to come)
- The figure above is a rendered D3 line chart of the temperature data fetched from a forecast request for the time of April 4, 2018 at 11:00 am to April 7, 2018 at 11:00 am.
- The next step is to serve up this page from a Flask server end-point!
- From the figure above,
-
Since the data was not rendering properly (despite being successfully passed from server to html), I hard-coded the data into the HTML page to produce this figure. I'll have to explore the code and read up more, on
D3
to hopefully solve the issue. -
Update: This has now been solved (see figure below).
-
- The issue was in the differences between the y-axis scaling between the historical and frecasted data. When integer values were input instead of
D3
calls to the data, the time series properly rendered!
- The weather temperature data returned from the forecast request.
- The weather temperature data returned from the time-machine request.
Data Parameters (found at forecast.io) - Hourly Data
(for full details on request response formats, see here)
apparentTemperature
: 'feels like' temp in FarenheitcloudCover
: percentage of sky occluded by clouds, between 0 and 1, inclusive.dewPoint
: dew point in deg. Farenheithumidity
: relative humidity, between 0 and 1, inclusiveicon
: machine-readable text summary of data-point, suitable for selecting an icon for display.- If defined
- will have one of the following values,
clear-day
clear-night
rain
snow
sleet
wind
fog
cloudy
partly-cloudy-day
partly-cloudy-night
- will have one of the following values,
- If defined
ozone
: columnar density of total atmospheric ozone at the given time (in Dobson units)precipIntensity
: intensity (in inches of liquid of water per hour) of precipitation occurring at a given time.precipProbability
: probability of precipitation occurring, between 0 and 1, inclusiveprecipType
: type of precipitation occurring at a given time.pressure
: sea-level pressure in millibarssummary
: human-readable text summary of data pointtemperature
: air-temp in deg. Farenheittime
(unix
timestamp):UNIX
time at which data point begins.uvIndex
: UV indexvisibility
: average visibility in miles, capped at 10 mileswindBearing
: direction that the wind is coming from in degrees, with true north at 0$^o$ and progressing clockwisewindGust
: wind gust in miles / hrwindSpeed
: wind speed in miles / hr