Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/sundios/seo-dashboard

SEO dashboard from Search console Data using the Google Search API, Mysql database , NodeJS RESTAPI( ExpressJS) and reactJs Dashboard
https://github.com/sundios/seo-dashboard

dashboard etl-kpi etl-pipeline expressjs google-search-console google-search-console-python mysql node-js react rest-api seo seo-monitor seotools

Last synced: 3 months ago
JSON representation

SEO dashboard from Search console Data using the Google Search API, Mysql database , NodeJS RESTAPI( ExpressJS) and reactJs Dashboard

Awesome Lists containing this project

README

        

# SEO ETL + React Dashboard

Check this other SEO project in production --> http://keywordresearchtool.io/

> This is an ETL project that is focused on having a complete SEO dashboard for reporting purposes. This is the first version of this project and only includes basic data from Google. I'm working on including more metrics like Backlink profiles, Daily rankings for specific keywords, Search volumes and more.


![alt text](https://panoply.io/uploads/versions/diagram4---x----750-328x---.jpg)

## Task and Goal
The task for this project is to create an ETL pipeline using Google search organic traffic and load the data in a user-friendly dashboard. Our ETL process performs data cleaning during the extraction process and loads significant data into a data warehouse. Our main goal for this project is by having this pipeline we will be able to have the data in one place and make it easier for businesses stakeholders to access this data, analyze it and discover different business insights.

## Data Background
We will be working with Monthly Google search organic traffic from the domain https://www.tuves.cl. This data will be acquired by using the Google search API. We will use 9 different data sets of search traffic and they are the following:

- **Mobile, Desktop and Tablet - Day to day Organic data**: These are multiples CSV files that are organized by date and includes Keywords, Clicks, Impressions, CTR, Ranking, Device and Date.
- **Mobile, Desktop and Tablet - Monthly Top 10 Keywords**: One data set that includes Keyword, Clicks, Impressions, Avg CTR and Avg Ranking for the specific device and time frame.
- **Mobile, Desktop and Tablet - Monthly Top 10 URLs**: One data set that includes URL, Clicks, Impressions, Avg CTR and Avg Ranking for the specific device and time frame.

## Approach and Methods used
This project is composed by 5 steps.
1. **Extraction**: Extract the Google search data using the Google search API. Our data will be saved in CSV files. This is folder **0Google Top Kws&urls** and **1Google API Day to day**. We are using the Google search console and a python script to perform this step.

2. **Transform**: Transform the day to day data into 3 monthly data sets. A mobile data set, a desktop and a tablet. The Keywords and URLs are ready to go. This is in folder **2data-cleaning**. We are cleaning the data with a python script I created.

3. **Load**: Load the data to the data warehouse. We will be using a MySQL database. This is in folder **3data-to-sql**. We are loading our data to MySQL using a python script I created.

4. **Load**: Build a REST API that will parse all of our MySQL tables into JSON. This is in folder **4RESTapi**. We are using NodeJS and ExpressJS to build our restful API.

5. **Analyze**: Create a dashboard where we will load our data and analyze it using tables and visualizations. This is in folder **dashboard**. Reactjs, ChartJS, Axios, and Reactstrap.

## Visualizations

![alt text](dash.gif)

## Full report

You can find detailed information here --> [Full report](https://github.com/sundios/SEO-Dashboard/blob/master/Full_report.pdf)