kredi_hesaplama / app.py
yunuseduran's picture
Update app.py
5ff0a1c verified
raw
history blame
6.18 kB
import streamlit as st
import pandas as pd
import json
import io
# Oyuncu sınıfı tanımı
class Player:
def __init__(self, name):
self.name = name
self.league_position = None
self.target_hit = None
self.cup_stage = None
self.yellow_cards = 0
self.red_cards = 0
self.goals_conceded = 0
self.goals_scored = 0
self.interviews = 0
self.penalty_points = 0
self.score = 0
# Veri kaydetme fonksiyonu
def save_data(players, filename="players.json"):
data = []
for player in players:
player_data = {
"name": player.name,
"league_position": player.league_position,
"target_hit": player.target_hit,
"cup_stage": player.cup_stage,
"yellow_cards": player.yellow_cards,
"red_cards": player.red_cards,
"goals_conceded": player.goals_conceded,
"goals_scored": player.goals_scored,
"interviews": player.interviews,
"penalty_points": player.penalty_points,
"score": player.score
}
data.append(player_data)
with open(filename, "w") as f:
json.dump(data, f, indent=4)
# Veri yükleme fonksiyonu
def load_data(filename="players.json"):
try:
with open(filename, "r") as f:
data = json.load(f)
except FileNotFoundError:
data = []
players = []
for player_data in data:
player = Player(player_data["name"])
player.league_position = player_data["league_position"]
player.target_hit = player_data["target_hit"]
player.cup_stage = player_data["cup_stage"]
player.yellow_cards = player_data["yellow_cards"]
player.red_cards = player_data["red_cards"]
player.goals_conceded = player_data["goals_conceded"]
player.goals_scored = player_data["goals_scored"]
player.interviews = player_data["interviews"]
player.penalty_points = player_data["penalty_points"]
player.score = player_data["score"]
players.append(player)
return players
# Fair play ödüllerini belirleme
def calculate_fair_play_points(players):
min_yellow_cards = min(players, key=lambda p: p.yellow_cards).yellow_cards
min_red_cards = min(players, key=lambda p: p.red_cards).red_cards
for player in players:
if player.yellow_cards == min_yellow_cards and player.red_cards == min_red_cards:
player.score += 1
# En az gol yiyen ve en çok gol atan takımlara ödül verme
def calculate_goal_awards(players):
min_goals_conceded = min(players, key=lambda p: p.goals_conceded).goals_conceded
max_goals_scored = max(players, key=lambda p: p.goals_scored).goals_scored
for player in players:
if player.goals_conceded == min_goals_conceded:
player.score += 1
if player.goals_scored == max_goals_scored:
player.score += 1
# Uygulama başlatıldığında verileri yükle
players = load_data()
# Oyuncu ekleyici bölümü
st.title("Özel Online Score Manager Ligi")
player_name = st.text_input("Oyuncu İsmi")
player_league_position = st.number_input("Lig Sıralaması", min_value=1, max_value=20)
player_target_hit = st.selectbox("Hedef Tutturması", options=[1, -1], index=0)
player_cup_stage = st.selectbox("Kupa Aşaması", options=[4, 3, 2, 1], index=0)
player_yellow_cards = st.number_input("Sarı Kartlar", min_value=0)
player_red_cards = st.number_input("Kırmızı Kartlar", min_value=0)
player_goals_conceded = st.number_input("Yenilen Goller", min_value=0)
player_goals_scored = st.number_input("Atılan Goller", min_value=0)
player_interviews = st.number_input("Röportaj Sayısı", min_value=0)
if st.button("Ekle"):
player = Player(player_name)
player.league_position = player_league_position
player.target_hit = player_target_hit
player.cup_stage = player_cup_stage
player.yellow_cards = player_yellow_cards
player.red_cards = player_red_cards
player.goals_conceded = player_goals_conceded
player.goals_scored = player_goals_scored
player.interviews = player_interviews
players.append(player)
st.success(f"{player_name} eklendi!")
# Hesapla bölümü
if st.button("Hesapla"):
calculate_fair_play_points(players)
calculate_goal_awards(players)
st.success("Hesaplamalar yapıldı ve ödüller verildi!")
save_data(players)
# Sonuçları görüntüleme
st.header("Sonuçlar")
for player in players:
st.subheader(player.name)
st.write(f"Lig Sıralaması: {player.league_position}")
st.write(f"Hedef Tutturması: {player.target_hit}")
st.write(f"Kupa Aşaması: {player.cup_stage}")
st.write(f"Sarı Kartlar: {player.yellow_cards}")
st.write(f"Kırmızı Kartlar: {player.red_cards}")
st.write(f"Yenilen Goller: {player.goals_conceded}")
st.write(f"Atılan Goller: {player.goals_scored}")
st.write(f"Röportaj Sayısı: {player.interviews}")
st.write(f"Puan: {player.score}")
st.write("---")
# Excel çıktısı
def to_excel(df):
output = io.BytesIO()
writer = pd.ExcelWriter(output, engine='openpyxl')
df.to_excel(writer, index=False, sheet_name='Oyuncu Verileri')
writer.close()
output.seek(0) # Dosya başlangıcına geri dön
processed_data = output.getvalue()
return processed_data
if st.button("Excel İndir"):
df_players = pd.DataFrame([
{
"Oyuncu": player.name,
"Lig Sıralaması": player.league_position,
"Hedef Tutturması": player.target_hit,
"Kupa Aşaması": player.cup_stage,
"Sarı Kartlar": player.yellow_cards,
"Kırmızı Kartlar": player.red_cards,
"Yenilen Goller": player.goals_conceded,
"Atılan Goller": player.goals_scored,
"Röportaj Sayısı": player.interviews,
"Puan": player.score
}
for player in players
])
excel_data = to_excel(df_players)
st.download_button(label="Excel İndir", data=excel_data, file_name='oyuncu_verileri.xlsx', mime='application/vnd.openxmlformats-officedocument.spreadsheetml.sheet')