This project showcases my data science projects on a deployed website.
Latest update: The color of the navbar was changed.
05/25/2021: I linked the latest blog post and project on the index page to the database and removed the hard-coded text from the HTML. The maximum content width was limited by putting everything into containers.
- Installation
- Project Motivation
- To Do
- Instructions
- File Descriptions
- Licensing, Authors, Acknowledgements
The code requires Python versions of 3.* and general libraries available through the Anaconda package. In addition, psycopg2 for the PostgreSQL database, Flask, Werkzeug and gunicorn need to be installed to be able to deploy the website. Please refer to the requirements.txt
file for more details on dependencies.
I wanted to have a space to showcase my projects with references to their code, blog posts and deployed apps, where applicable. I also added more details about my learning path towards data science and the skills I acquired.
- TODO: Change layout of Portfolio page
- TODO: Change color scheme
- TODO: Add some JavaScript to make the look nicer
The database containing the content for the website is a PostgreSQL database on Heroku.
If you want to update the database, you need to connect to the remote database in your local environment. Follow the below steps to connect to a Heroku PostgreSQL database locally:
- Install the Heroku CLI.
- Create a PostgreSQL database on Heroku that is linked to this app.
- Install PostgreSQL on your computer locally and update your PATH environment variable to add the bin directory of your Postgres installation. (More details here)
- Get the database credentials by running
heroku pg:credentials:url -a <your app name>
. Copy the Connection URL. - Type into your shell
$ export DATABASE_URL=postgres://<Connection URL>
if you're using a Mac or Linux and$ set DATABASE_URL=postgres://<Connection URL>
if you're using Windows. (See the documentation here)
Now your local environment has the DATABASE_URL for your remote Heroku PostgreSQL database saved and the code in app.py can access this database from your local computer.
If you want to update the database content, you need to create Excel files containing the relevant information you want to display on the website.
Running python database_feeder.py
will read the data from the Excel files into the database.
Please note: There is currently no feature in this file that deletes and creates a new database if a new column is added. Adding of rows is handled, but not of columns. Therefore, if you want to add a new column to the Excel file and then database, you need to first reset the PostgreSQL in the app on Heroku and then you need to add the relevant code to the script, before running it.
The templates
folder contains all html pages that will be accessible through the site. The static
folder is made up of the images displayed on my website, the robots.txt site as well as the css stylesheet. app.py
is the file which will render the website through the micro web framework Flask. database_feeder.py
is the script that reads in the data from the Excel files into the database. And the helper.py
file contains the functions querying the database when a html page is rendered.
This code can be used under the MIT license. I created this website completely from scratch, therefore I am the author of the code, including certain references and code snippets from other people which I marked appropriately. Feel free use the code - but remove any of the content relating to me - to create your own portfolio website.