Skip to content

Analysis of a retail company sales using data analytics and Power BI

Notifications You must be signed in to change notification settings

victor-malheiro/PowerBI

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 

Repository files navigation

Sales Performance Analysis

This project aims to analyze and monitor the sales performance of a retail store using DAX queries and a Power BI dashboard. The project provides insights into sales trends, the profits of the products sold, who bought it and in which market.

The repository contains a Power BI dashboard for visualizing and analyzing several metrics and also the data used in it.

Table of Contents

  1. Project Statement
  2. Objectives
  3. Dataset
  4. Data Modeling
  5. PowerBI Dashboard
  6. Recommendations

Project Statement

The objective of this project is to conduct a comprehensive analysis of the Global Superstore dataset, focusing on sales, products, markets and customers. To achieve this goal, i will employ data modeling and data transformation techniques to refine the dataset, ensuring that the most relevant columns are considered on the analysis, while using an eficient data model.

Using DAX, i will extract meaningful insights and patterns that are important to understand which costumers and markets are the most important to maximize sales and profitability. This approach not only provides a more insightfull analysis but it also facilitates the understanding of the factors that influence sales and profit.

Objectives

With this dashboard i want to answer several question to help understand the business performance and how it can be improved in the future.

  • Which are the sales tendency over time for the different categories of products?
  • Find out the total sales per market over time.
  • Which products are more or less profitable?
  • Show the category of products and the respective sub-categories that are more profitable, depending on the market and segment of products.
  • Find out which countries have more orders placed and which ones are more profitable.
  • Show the average number of days that takes to ship an order on the countries of a certain market.
  • Classify the costumer by the number of orders to understand which costumers are the most profitable.
  • Identify customers who have placed a high volume of orders but have stopped ordering for a certain period of time, in order to reduce the churn rate.

Dataset

The dataset used is the Global Superstore dataset with 23 features and 51291 different orders, in a time period of four years. The orders where placed by 1590 customers, from 146 countries and distributed between seven markets. The store has 10292 different products, divided into 3 different categories and 17 sub-categories, that are placed in 3 distinct segments.

Data Modeling

To query and work with the data faster and easily, the dataset was divided into four tables using a star schema. This schema has three dimension tables, called City, Customers and Products, and one fact table called Orders, that was normalized avoiding the repetition of the data of the other three tables.

image

PowerBI Dashboard

The PowerBI Dashboard provides visualizations and oportunities to analyze different metrics that were defined on the Objectives section. The dashboard presents several information, using visualization and DAX programming, divided into four different pages that can be accessed by the navigation buttons and with a time slicer to analyze all the resullts over time.

On the first page i created two charts representing on the first one the sales over time by category and on the second, the trend of the sales by market, using a tooltip to present the top 5 countries in each market as an additional representation, to understand who contributed the most for the results presented.

image

The second page was created to analyze which products contribute the most or not to the profits of the store. A pie chart was created to know how the categories, and sub-categories using a tooltip, contribute to the global profit.

Two tables were also inserted to analyze which are the five products that are more profitable and another one to analyze which products contribute less to the profits, with the respective values.

All this information can be further filtered using two additional slicers, one for the market and another for the segment of products.

image

To analyze the markets in more detail, a third page was created where the top 10 countries that are more important to the profits are presented, and also the number of orders per country.

A table was also added to show the average number of days that is need to ship an order in each country. This was done creating a calculated table where the number of days from the order date to the ship date was computed, using the DAX code below.

ShipTimeinDays = DATEDIFF(Orders[Order Date], Orders[Ship Date],DAY)

These visualizations can be filtered using a slicer where the different markets can be chosen.

image

Finally, a fourth page was created to analyze the costumers that bought items on the store, a chart was created to show the 10 clients that created more orders.

Two pie charts were also created, the first one is to show the total profit divided by a client classification created by me, to divide the clients by the volume purchased. This chart was based on a calculated column called "ClientClassification" that divided the clients on three classes, the clients with low, medium and high volumes of orders.

ClientClassification = SWITCH(TRUE(),
        [numOrdersClient] >= 70, "High Volume Client",
        [numOrdersClient] >= 20, "Medium Volume Client",
        "Low Volume Client")

To create the client classification, a measure with name "numOrdersClient" was computed to know the number of orders each client has.

numOrdersClient = CALCULATE(count(Orders[Order ID]))
The second pie chart represents the number of customers that need a certain action action to be taken. This action is based on the number of orders the client has, but for some reason the client stopped ordering for a certain period of time, this is done in order to reduce the churn rate.

Three different actions are advised, the first one is to contact the client immediatly, then it is to contact the client ASAP and the last one is to identify the number of clients that do not need to be contacted.

To know the action to be taken for each client, three calculated columns were created. The first one is to know when the last order of each client was created.

LastOrder = CALCULATE(
                MAX(Orders[Order Date]),
                FILTER(
                    ALL(Orders),
                    Orders[Customer ID] = Customers[Customer ID]
                )
            )

The second column was created to know how many days passed since the last order a certain client made.

DaysFromLastOrder = DATEDIFF(Customers[LastOrder], TODAY(),DAY)

And finally, the action to be taken for each client was decided.

Action = 
    IF(Customers[DaysFromLastOrder] > 3500 && (Customers[ClientClassification] = "High Volume Client" || Customers[ClientClassification] = "Medium Volume Client"), "Contact Client Immediatly",
    IF(Customers[DaysFromLastOrder] >= 2500 && (Customers[ClientClassification] = "High Volume Client" || Customers[ClientClassification] = "Medium Volume Client"), "Contact Client ASAP",
    "Do Not Contact Client"))
All the visualizations could be filtered by the market with the help of a slicer, that enables the drill down of the market by the country and the city.

image

Recommendations

To access the dashboard, open the StoreGlobalOrders.pbix file in Power BI Desktop, interact with the visualizations on the different pages, that can be navigated using the navigation buttons on the top of each page, apply filters and slicers, to analyze all the data over a certain period time.

The dashboard is usefull to gather knowledge about the sales information and about the products sold, the costumers that bought them and the respective markets, to help the management take more informed decisions.

Copyright

© 2024 Victor Malheiro