Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/revogati/ecommerce_consumer_behaviour
This is a Full Data Analytics project From data cleaning, preparation, exploration, Interpretation of insights up to Presentation of findings and recommendations..
https://github.com/revogati/ecommerce_consumer_behaviour
data-analysis data-exploration ecommerce jupyter-notebook python sql tableau-public visualization
Last synced: 14 days ago
JSON representation
This is a Full Data Analytics project From data cleaning, preparation, exploration, Interpretation of insights up to Presentation of findings and recommendations..
- Host: GitHub
- URL: https://github.com/revogati/ecommerce_consumer_behaviour
- Owner: REVOgati
- Created: 2023-11-08T08:23:15.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-02-23T13:58:11.000Z (11 months ago)
- Last Synced: 2025-01-07T23:48:55.012Z (14 days ago)
- Topics: data-analysis, data-exploration, ecommerce, jupyter-notebook, python, sql, tableau-public, visualization
- Language: Jupyter Notebook
- Homepage:
- Size: 791 KB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# **Analysis of Consumer Behaviour in an Ecommerce Grocery Business**
## Table of Contents
1. [Project Overview](#project-overview)
2. [Data Sources](#data-sources)
3. [Tools Used](#tools-used)
4. [Data Cleaning and Preparation](#data-cleaning-and-preparation)
5. [Exploratory Data Analysis](#exploratory-data-analysis)
- [Customer Segmentation](#1-customer-segmentation)
- [Product Purchase Insights](#2-product-purchase-insights)
- [Time-related Patterns](#3-time-related-patterns)
- [Cart Analysis](#4-cart-analysis)
6. [Data Visualization](#data-visualization)
7. [Findings](#findings)
8. [Limitations and Assumptions](#limitations-and-assumptions)
9. [Recommendations to Ecommerce Store and Conclusion](#recommendations-to-ecommerce-store-and-conclusion)
10. [References](#references)---
### **PROJECT OVERVIEW**
**Bussiness Problem** : Improving customer retention and determining product purchase patterns.**Description:**
- The dataset contains information about customer orders, including the day of the week, hour of the day, and days since the prior order.- We can use this data to analyze customer behavior and identify patterns related to purchase of different products.
- The goal is to determine product purchase and re-ordering patterns in relation to consumer behaviour.
- Therefore, the analysis will consists of the following target areas:
**1. Customer Segmentation:**\
- What are the distinct customer segments?\
- How can we categorize customers as new or existing?\
-Purporse : To determine the general nature of the Online Store's Users.
**2.Product purchase Insights:**\
- Identify which products have the highest sales and re-ordering rate and vice-versa.\
- Purporse : To identify the best performing and least performing products, and draw reasons behind this, to help in improving the business sales.**3. Time-related Patterns:**\
- Explore the order time of the day and day of the week to identify peak shopping times.\
- Calculate which time of the 24hour clock are most orders made, and which ones.\
-Purporse: To help in human resource scheduling and iventory planning.**4. Cart Analysis:**\
- Items per Cart: Explore the number of products added to a cart per order.\
- Cart Abandonment: Identify instances where products are added to the cart but not purchased.\
- Purporse: Determine the rate of product abandonment and how to reduce this.### **Data Sources**
- The dataset was sourced from a Kaggle account[Click here to view account](https://www.kaggle.com/hunter0007)
- The dataset is from a real E-commerce grocery store called ; 'Hunter's e-grocery for their orders in a given time period in the year 2023 as explained [here](https://www.kaggle.com/datasets/hunter0007/ecommerce-dataset-for-predictive-marketing-2023/data).
### **Tools Used**
- **Cleaning and Preparation:** Python programming language was used for data cleaning and preparation. Python is powerful and efficient for handling large datasets.
- **Exploratory Data Analysis:** Python and SQL were utilized for data analysis and insights extraction.
- **Visualizations:** Tableau was used to effectively display findings.
- **Presentation:** Google Slides were employed to create a simplified explanation of the entire process, ensuring easy understanding even for those unfamiliar with data analysis.
### **Data Cleaning and Preparation**
**Overview of the data**:
The dataset contains the following columns:
- order_id - unique identity of order
- user_id -unique identity of user/customer
- order_number - Number OF THE ORDER
- order_dow -Day of the Week the order was made(either 0,1,2,3,4,5,6) - '0' represents Monday and '6' represents Sunday
- order_hour_of_day - Hour of the day order was made
- days_since_prior_order - Days since prior order ; 0 for new customers, the rest depending on last day
- product_id - unique ID of product that is part of an order
- add_to_cart_order - Number of specific products added to cart as part of the order
- reordered - If the re-order took place ( is in binary of 0 or 1)
- department_id - specific department identity that an ordered product is part of.
- department - name of department
- product_name - name of product
**Raw dataset**
- For detailed information: [Click here to view and download original dataset](https://drive.google.com/file/d/1-6CzS3g7AOjxRwwndnUUHWhF5_Bec5Xn/view?usp=sharing)The following are the steps in my data cleaning process:
**Clean dataset**
- After cleaning and preparation process, the cleaned dataset was also uploaded in my Google Drive: [Click here to view and download clean dataset](https://docs.google.com/spreadsheets/d/1Fyxl9P_ApXpDl7CixTMg-Z0m8FMBve5D/edit?usp=drive_link&ouid=102527141955837924247&rtpof=true&sd=true)### **Exploratory Data Analysis**
- #### **1. Customer Segmentation:**
- In the original dataset, the order_id column has duplicate values.\
- This is because every order was brocken down to individual products contained in the specific order, leading to a repeat of a unique order.\
- Thus, I combined the products in respective order batches in order to handle duplicate values.
- With this, I eliminated data duplication and was able to analyze the different groups of customers.\
- Click to view the SQL file: [SQL_Consumer_Segmentation] (https://github.com/REVOgati/Ecommerce_Consumer_Behaviour/blob/155c3faa481e21f0e32490816ee21f0323d13587/SQL_Consumer_Segmentation.sql)- #### **2. Product purchase Insights:**
1. Which products are most ordered in specific departments in the dataset? - To determine the most and least purchased products in every department.\- I used SQL to group products by departments, and return the total number of orders of each product.\
-A snapshot of the SQL code and the link:[Product purchase insights](https://github.com/REVOgati/Ecommerce_Consumer_Behaviour/blob/699fffc3648a992227998da47087a37e1e340930/sql_exploration_files/products_insights.sql)
2. Which products are most re-ordered and vice-versa, and why? - To determine which products attract most purchases and vice-versa.
- #### **3. Time-related Patterns:**
- At what time of the 24hour day, are the highest orders made? - To help in human resource allocation\
- At what day of the week are the highest orders made?\
- What time of the day, is the most purchased products mostly ordered?1. I grouped the items according to the values of the 24hour day to determine the time with highest orders.\
2. Since 0 represents Monday, and 6 represents Sunday, I used SQL to return number of orders for every day.\
3. I used an SQL code that returns the most ordered product, and its different purchase time periods.- #### **4. Cart Analysis:**
- For every ordered item, I subtracted the number in the cart - order number to determine number of abandoned items and multiplied by 100.
- This in order to get the percentange rate of cart abandonment.
- I then stored the result in a new column 'abandoned_items' and counted the total number per product.
- ### **Data Visualization**
- Visual representations are available on [Tableau Public](https://public.tableau.com/app/profile/gareth.tirop/viz/EcommerceStoreAnalysis_17080716552270/EcommerceStoreOrdersAnalysis).### **Findings**
- **Consumer Segmentation**
- There 103,761 unique orders made.
- Approximately 8,405 entries with value 0 in days_since_prior_order, indicating new users.
- Majority of customers are returning users.- **Product purchase patterns**
- The most top six most ordered products are 'fresh fruits', 'fresh vegetables','packaged vegetables' 'fruits', 'youghurt', 'milk' and 'packaged cheese' respectively.\
- These six fall under the departments of either 'produce' or 'dairy eggs', each having three items.\- The least ordered products are 'frozen juice', 'shave needs', 'beauty', 'first aid', 'eye ear care' and 'kitchen supplies' respectively.\
- Four of these items fall under the department 'personal care' with 'frozen' and 'household' having each one.- **Time-related patterns**
1. - The hours 10,11,14,15,13,12 have the highest number of orders.\
-The hours 3,4,2,5,1,0 have the least number of orders.\
- The above data can inform human resource allocation in the recommendations section below.\2. - The highest number of orders are made on Friday while the least being made on Monday.\
- This result may be attributed to factors only unique to the specific grocery store as much cannot be explained based of a global point of view.\
3. - The most ordered product is fresh fruits.
- The time period 10am to 3pm has the highest number of orders for fresh fruits\
- while the time period of 12am to 5am has the least number of orders for fresh fruits.\- **Cart Analysis**
- All results were either less than 1% or a negative for the percentage rate of cart abandonment.\
- This means that the percentage of users abandoning items they add to Cart is extremely low.\
- Therefore, this is not a problem for this Ecommerce Store.\
- An assumption may be, since most users are returning customers, they are well aware of the satisfying quality of the products they order.\
- Or, due to essential nature of grocery items being sold.
### **Limitations and Assumptions**
1. There were many unique USER_IDs that had more than 1 occurence of the value 0 in the days_since_prior_order column.\
-I assumed they may have made more than 1 order in their first day as the only possible explanation. \
- I used filtering and grouping techniques to handle this and get the correct number of new users in the period.\2. The data is collected over a long period of time, however the limit is set to 30 days.\
- Therefore, those users that only bought once in this period are given the value 30 in the 'days_since_prior_order' column.\
- Therefore, those with 30 in the said column are not new users, but already established users,that have not ordered in a long period.\### **Recommendations to Ecommerce Store and Conclusion**
1. **On products insights**\
- Given that the departments 'produce' or 'dairy eggs' have the highest orders, I would recommend measures to ensure consistency of quality of these products as well as their availability.\
- Given that the departments 'personal care', 'frozen' and 'household' have the lowest orders, measures should be put in place to promote products of these departments.\
- They might include improvement of product quality, research from users, advertisements or discounts.2. **Time-related**
- I would recommend that there should be a significantly higher number of human resource allocation of the employees in the period 10am - 3pm due to the higher number of orders.
- Thus, there should be a smaller group at the hours 12am to 5am due to the lower number of orders.
- This helps to balance the number of human resource against traffic in order to ensure optimality in performance.3. **Consumer Segementation**
- 8% of all the customers are new users while the rest are exisiting users.
- This means that a very huge number of customers are returning.
- I would recommend surveys to understand reasons for returning customers.4. **Cart Analysis**
- The store does not have a major problem with cart abandonment as the average rate is at a percentage of less than 1%.
- This might be due to the essential nature of most of its products as groceries and household items are always very readily needed.### **References**
- **Visualizations** : Path to my Tableau Dashboard for this project : [Ecommerce Store Viz](https://public.tableau.com/app/profile/gareth.tirop/viz/EcommerceStoreAnalysis_17080716552270/EcommerceStoreOrdersAnalysis)
- **Data Source** :
- The dataset was sourced from a Kaggle account[Click here to view account](https://www.kaggle.com/hunter0007)- The dataset is from a real E-commerce grocery store called ; 'Hunter's e-grocery for their orders in a given time period in the year 2023 as explained [here](https://www.kaggle.com/datasets/hunter0007/ecommerce-dataset-for-predictive-marketing-2023/data).