Spaces:
Runtime error
Runtime error
Commit
·
fe8f546
1
Parent(s):
0ccea66
Update app.py
Browse files
app.py
CHANGED
|
@@ -0,0 +1,60 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import streamlit as st
|
| 2 |
+
import pandas as pd
|
| 3 |
+
import plotly.express as px
|
| 4 |
+
import plotly.graph_objects as go
|
| 5 |
+
|
| 6 |
+
st.title("Customer Lifetime Value App")
|
| 7 |
+
|
| 8 |
+
# Read the dataset
|
| 9 |
+
data = pd.read_excel('Online Retail.xlsx')
|
| 10 |
+
|
| 11 |
+
# Get the user id
|
| 12 |
+
user_id = st.selectbox('Select the user id :', data.CustomerID.unique())
|
| 13 |
+
|
| 14 |
+
# Get the data for the selected user id
|
| 15 |
+
user_data = data[data['CustomerID'] == user_id]
|
| 16 |
+
|
| 17 |
+
# Calculate the CLV
|
| 18 |
+
clv = (user_data.UnitPrice * user_data.Quantity).sum()
|
| 19 |
+
|
| 20 |
+
st.write('Customer lifetime value : ', clv)
|
| 21 |
+
|
| 22 |
+
# Calculate the next purchase date
|
| 23 |
+
purchase_date = user_data.InvoiceDate.max()
|
| 24 |
+
|
| 25 |
+
st.write('Next purchase date : ', purchase_date)
|
| 26 |
+
|
| 27 |
+
# Get the purchase trend
|
| 28 |
+
user_data['InvoiceDate'] = pd.to_datetime(user_data['InvoiceDate'])
|
| 29 |
+
user_data['Day'] = user_data['InvoiceDate'].dt.day
|
| 30 |
+
user_data['Month'] = user_data['InvoiceDate'].dt.month
|
| 31 |
+
user_data['Week'] = user_data['InvoiceDate'].dt.week
|
| 32 |
+
user_data['Year'] = user_data['InvoiceDate'].dt.year
|
| 33 |
+
|
| 34 |
+
# Plot the graphs
|
| 35 |
+
st.subheader('Purchase Trend')
|
| 36 |
+
|
| 37 |
+
# Day Wise
|
| 38 |
+
fig = go.Figure()
|
| 39 |
+
fig.add_trace(go.Scatter(x=user_data.Day, y=user_data.Quantity, mode='lines+markers', name='Day Wise'))
|
| 40 |
+
st.plotly_chart(fig)
|
| 41 |
+
|
| 42 |
+
# Date Wise
|
| 43 |
+
fig1 = px.line(user_data, x="InvoiceDate", y="Quantity", title='Date Wise')
|
| 44 |
+
st.plotly_chart(fig1)
|
| 45 |
+
|
| 46 |
+
# Week Wise
|
| 47 |
+
fig2 = go.Figure()
|
| 48 |
+
fig2.add_trace(go.Scatter(x=user_data.Week, y=user_data.Quantity, mode='lines+markers', name='Week Wise'))
|
| 49 |
+
st.plotly_chart(fig2)
|
| 50 |
+
|
| 51 |
+
# Month Wise
|
| 52 |
+
fig3 = go.Figure()
|
| 53 |
+
fig3.add_trace(go.Scatter(x=user_data.Month, y=user_data.Quantity, mode='lines+markers', name='Month Wise'))
|
| 54 |
+
st.plotly_chart(fig3)
|
| 55 |
+
|
| 56 |
+
# Risk of Churn
|
| 57 |
+
if clv <= 0:
|
| 58 |
+
st.write('Risk of Churn : Yes')
|
| 59 |
+
else:
|
| 60 |
+
st.write('Risk of Churn : No')
|