Weather on the Web With Sense Hat

by ZRob314 in Circuits > Raspberry Pi

5112 Views, 12 Favorites, 0 Comments

Weather on the Web With Sense Hat

website.PNG

The following components are used for this project:

Raspberry Pi 3

Sense Hat

Sense Hat case

HDMI Cable

Monitor

Keyboard

Mouse

Looking for a great introduction to Raspberry Pi? Try the Zagros Raspberry Pi 3 Starter Kit which has everything you need to begin discovering Raspberry Pi.

Revise Weather Display.

57d1d1f667400cfd39001735.jpeg

This tutorial begins with a Python file from a previous instructable: Weather Display with Sense Hat.

You can go back and follow that instructable first or download and open this file in a Python 3 editor for the next steps.

Downloads

Install and Import Flask Framework to Project.

580937594fbade1137000235.jpeg

Install Flask. In the Terminal type:

sudo apt-get install python3-flask

Import Flask to your project. In the weather_log.py file add this line below the other imported modules:

from flask import Flask

Python Code to Display HTML on the Web.

weather_log_flask.png

Insert this code just below the "message" variable and save it. We will build out the rest of the app in future steps.

Python is space sensitive, the entire code below the line of 'def index():' should be indented.

@app.route('/')

def index();

now = str(asctime())

currentWeather = now + " " + "-" + message + "\n"

weatherData = {

'weather': currentWeather

}

return render_template('index.html', **weatherData)


You can go ahead and delete the while True: statement at the bottom of the code. In this step we have moved it inside the index function. The 'weather' property will be passed to the double curly braces in the HTML.

Create a Web App Folder for Your Project.

58093e824fbade1137000266.jpeg

Create a folder webapp in the pi directory.

Create two subfolders templates and static.

Create an Index.html File From the Text Editor.

580a423c67400cf1870008bd.jpeg

Navigate to Menu > Accessories > Text Editor

Paste in this section of HTML and save it under the templates folder with a file name of index.html.

<html>
  <head>
    <link rel = "stylesheet" href = "/static/style.css" />
  </head>
  <body>
    <h1>Weather:</h1>
    <h2>{{weather}}</h2>
  </body>
</html>

Style Your App.

580a42972e7fb678a90008e0.jpeg

Create a new file in the text editor save it in the static folder with a file name of style.css.

Paste this CSS code into the editor. Feel free to get creative and change the colors and style to your liking.

body {
background: navy;

color: yellow;

font-family: Arial, sans-serif;

text-align: center;

}

h1 {

border-bottom: 1px solid gold;

margin-bottom: 40px;

padding: 10px;

}

Start the Web Server.

580a661867400cf1870009bb.jpeg

In Terminal run the web server by entering:

python3 webapp/weather_log.py

It should output the following:

* Running on http://0.0.0.0:5000/

* Restarting with reloader

Test Your App in a Browser.

website.PNG

With the web server running point your browser to:

http://127.0.0.1:5000/

This will also work on any computer on your network!

You should now see the current Temperature, Humidity and Pressure.

As long as the web server is running you can navigate to that site to get the latest weather.