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')