Skip to content

Latest commit

 

History

History
98 lines (72 loc) · 4.08 KB

File metadata and controls

98 lines (72 loc) · 4.08 KB

Feamzy Dashboard - Ironhack Final Project

by Léo Cavalcante


Link for the presentation

Feamzy Dashboard - Ironhack Final Presentation


Feamzy Dashboard Cover

Description

Dashboard developed to report informations from Feamzy app.

This dashboard was created with Python, using Dash as the web framework and Plotly as the visualization library.

I have learned the necessary informations via Charming Data YouTube channel, a course in Udemy and Dash and Plotly official documentations.


Content of the folder

  1. data folder: containing the raw databases.
  2. data_clean folder: containing the roughly cleaned databases.
  3. static folder: containing the images. In this case, only one: feamzy logo with blue background.
  4. cleaning_functions.py: python code to clean the databases.
  5. feamzy_dashboard.py: python code for the dashboard app.
  6. env: virtual environment to run the app on local machine.
  7. stopwords.txt: document with words to exclude from the wordclouds generated in the dashboard.
  8. requirements.txt: document with the libraries required to be installed in the virtual environment env in order to run the app.
  9. Procfile: document necessary for the deployment in Heroku.
  10. Jupyter Notebooks: they were used for tests of each function in the app, but it is not formalized and they therefore don't present a pleasant reading. These files are named Data Cleaning, Data Exploration and Data Manipulation & Visualisations.ipynb.

Note: For confidentiality reasons, the databases are ignored in this Git Repository.


Before running the application:

  1. Store the raw databases on the data folder.
  2. Run cleaning_functions.py, it will send roughly cleanend databases to data_clean folder. These new databases will be the files that will be read by the feamzy_dashboard file.

How to use it

$ # Go to the directory where the application is installed
$ cd femazy-dashboard
$
$ # Virtualenv modules installation (Mac/Unix based systems)
$ virtualenv env
$ source env/bin/activate
$
$ # Virtualenv modules installation (Windows based systems)
$ # virtualenv env
$ # .\env\Scripts\activate
$
$ # Install modules - SQLite Database
$ pip3 install -r requirements.txt
$
$ # Start the application (development mode)
$ python feamzy_dashboard.py
$
$ # Access the dashboard in the browser that will appear on the terminal, usually: http://127.0.0.1:5000/

Note: The authentification system has to be improven for multiple users (with different logins and passwords).


Codebase structure

The project is coded using blueprints, app factory pattern, dual configuration profile (development and production) and an intuitive structure presented bellow:

Simplified version

< PROJECT ROOT >
   |
   |-- requirements.txt          # Development modules - SQLite storage
   |
   |-- .env                      # Inject Configuration via Environment
   |
   |-- feamzy_dashboard.py       # Start the app - WSGI gateway
   ************************************************************************

Deployment instructions

I invite you to visit the following videos on YouTube describing in depth how to deploy it:

PS.: I would recommend Heroku, which is a widely used and proven web app deployer. PythonAnywhere is limited to 500MB of storage and this apps exceeds it. Therefore, it is necessary to pay a subscription.