zodiac_app.py / app.py
halimbahae's picture
Update app.py
1407118 verified
import streamlit as st
import pandas as pd
import datetime
import matplotlib.pyplot as plt
import numpy as np
import io
# Data: zodiac signs with date ranges and personality traits
zodiac_traits = {
'Aries': {'dates': ((3,21), (4,19)), 'traits': ['Courageous', 'Determined', 'Confident', 'Enthusiastic']},
'Taurus': {'dates': ((4,20), (5,20)), 'traits': ['Reliable', 'Patient', 'Practical', 'Devoted']},
'Gemini': {'dates': ((5,21), (6,20)), 'traits': ['Gentle', 'Affectionate', 'Curious', 'Adaptable']},
'Cancer': {'dates': ((6,21), (7,22)), 'traits': ['Tenacious', 'Highly Imaginative', 'Loyal', 'Emotional']},
'Leo': {'dates': ((7,23), (8,22)), 'traits': ['Creative', 'Passionate', 'Generous', 'Warmhearted']},
'Virgo': {'dates': ((8,23), (9,22)), 'traits': ['Loyal', 'Analytical', 'Kind', 'Hardworking']},
'Libra': {'dates': ((9,23), (10,22)), 'traits': ['Cooperative', 'Diplomatic', 'Gracious', 'Fair-minded']},
'Scorpio': {'dates': ((10,23), (11,21)), 'traits': ['Resourceful', 'Brave', 'Passionate', 'Stubborn']},
'Sagittarius': {'dates': ((11,22), (12,21)), 'traits': ['Generous', 'Idealistic', 'Great Sense of Humor']},
'Capricorn': {'dates': ((12,22), (1,19)), 'traits': ['Responsible', 'Disciplined', 'Self-control', 'Good Managers']},
'Aquarius': {'dates': ((1,20), (2,18)), 'traits': ['Progressive', 'Original', 'Independent', 'Humanitarian']},
'Pisces': {'dates': ((2,19), (3,20)), 'traits': ['Compassionate', 'Artistic', 'Intuitive', 'Gentle']},
}
# Compatibility scores between signs (1-10)
compatibility = pd.DataFrame(
data=[
[5,6,7,4,8,5,6,7,8,5,6,7], # Aries with Aries, Taurus, ... Pisces
[6,5,6,7,5,8,7,6,5,8,7,6],
[7,6,5,8,6,7,8,5,6,7,8,5],
[4,7,8,5,7,6,5,8,7,6,5,8],
[8,5,6,7,5,7,6,7,5,8,6,7],
[5,8,7,6,7,5,8,6,7,5,8,6],
[6,7,8,5,6,8,5,7,6,8,7,5],
[7,6,5,8,7,6,7,5,8,6,7,6],
[8,5,6,7,5,7,6,8,5,7,6,8],
[5,8,7,6,8,5,8,6,7,5,8,6],
[6,7,8,5,6,8,7,7,6,8,5,7],
[7,6,5,8,7,6,5,6,8,6,7,5]
],
index=list(zodiac_traits.keys()),
columns=list(zodiac_traits.keys())
)
# Helper to determine zodiac sign from birthdate
def get_zodiac_sign(month: int, day: int) -> str:
for sign, info in zodiac_traits.items():
start, end = info['dates']
start_month, start_day = start
end_month, end_day = end
# handle year wrap for Capricorn
if start_month == 12:
if (month == start_month and day >= start_day) or (month == end_month and day <= end_day):
return sign
else:
if (month == start_month and day >= start_day) or (month == end_month and day <= end_day) or (start_month < month < end_month):
return sign
return None
# Function to create radar chart
def create_radar_chart(traits, values, sign):
num_vars = len(traits)
# Compute the angle for each trait (360 degrees divided by number of traits)
angles = np.linspace(0, 2 * np.pi, num_vars, endpoint=False).tolist()
# The plot needs to be circular, so we repeat the first value to close the loop
values += values[:1]
angles += angles[:1]
# Create the radar chart
fig, ax = plt.subplots(figsize=(6, 6), subplot_kw=dict(polar=True))
# Plot the data
ax.fill(angles, values, color='blue', alpha=0.25)
ax.plot(angles, values, color='blue', linewidth=2) # Outline of the chart
# Set the labels for each axis (the traits)
ax.set_yticklabels([]) # Remove the radial ticks
ax.set_xticks(angles[:-1]) # Set the ticks for each trait
ax.set_xticklabels(traits, color='black', fontsize=12)
# Add the title
ax.set_title(f'{sign} Personality Traits', size=14, color='black', fontweight='bold')
# Show the radar chart
return fig
# Streamlit UI
st.title('Zodiac Matcher')
# Horoscope Section
st.header('Get Your Horoscope and Personality Traits')
birthdate = st.date_input("Enter your birthdate:")
if birthdate:
dt = datetime.datetime.strptime(str(birthdate), '%Y-%m-%d')
sign = get_zodiac_sign(dt.month, dt.day)
traits = zodiac_traits[sign]['traits']
st.subheader(f"Your zodiac sign is: {sign}")
st.write(f"Personality Traits: {', '.join(traits)}")
# Display Radar Chart for Zodiac Sign
trait_values = [9, 10, 8, 9] # Example trait values for the radar chart (can be adjusted)
fig = create_radar_chart(traits, trait_values, sign)
buf = io.BytesIO()
fig.savefig(buf, format='png')
buf.seek(0)
st.image(buf)
# Compatibility Section
st.header('Check Compatibility Between Two Zodiac Signs')
sign1 = st.selectbox('Select your sign:', list(zodiac_traits.keys()))
sign2 = st.selectbox('Select partner sign:', list(zodiac_traits.keys()))
if sign1 and sign2:
score = compatibility.at[sign1, sign2]
st.subheader(f"Compatibility Score between {sign1} and {sign2}: {score}")
# Plotting Compatibility Chart
fig, ax = plt.subplots()
ax.bar([sign1 + " & " + sign2], [score])
ax.set_ylim(0, 10)
ax.set_ylabel('Score (1-10)')
ax.set_title(f'{sign1} & {sign2} Compatibility')
buf = io.BytesIO()
plt.savefig(buf, format='png')
buf.seek(0)
st.image(buf)