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 = [] 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 # Kural ihlallerine göre ceza puanları ekleme def apply_penalty_points(players): penalties = { "Transfer ihlali": -3, "İç transfer ihlali": -5, "Aktiflik ihlali": -1, "Aynı takım arası iç transfer ihlali": -5, "Toplam iç transfer sayısı ihlali": -5, "Kadro planlaması ihlali": -6 } for player in players: for violation in player.penalty_points: if violation in penalties: player.score += penalties[violation] # Oyuncu ekleme işlevi def add_player(name, league_position, target_hit, cup_stage, yellow_cards, red_cards, goals_conceded, goals_scored, interviews, penalty_points): player = Player(name) player.league_position = league_position player.target_hit = target_hit player.cup_stage = cup_stage player.yellow_cards = yellow_cards player.red_cards = red_cards player.goals_conceded = goals_conceded player.goals_scored = goals_scored player.interviews = interviews player.penalty_points = penalty_points return player # DataFrame oluşturma işlevi def create_dataframe(players): df_players = pd.DataFrame({ "Oyuncu": [player.name for player in players], "Lig Sıralaması": [player.league_position for player in players], "Hedef Tutturması": [player.target_hit for player in players], "Kupa Aşaması": [player.cup_stage for player in players], "Sarı Kartlar": [player.yellow_cards for player in players], "Kırmızı Kartlar": [player.red_cards for player in players], "Yenilen Goller": [player.goals_conceded for player in players], "Atılan Goller": [player.goals_scored for player in players], "Röportaj Sayısı": [player.interviews for player in players], "Puan": [player.score for player in players] }) return df_players # Oyuncu ekleme bölümü st.title("Özel Online Score Manager Ligi") players = [] # Oyuncu listesi 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) player_penalties = st.multiselect("Kural İhlalleri", options=[ "Transfer ihlali", "İç transfer ihlali", "Aktiflik ihlali", "Aynı takım arası iç transfer ihlali", "Toplam iç transfer sayısı ihlali", "Kadro planlaması ihlali" ]) if st.button("Ekle"): new_player = add_player(player_name, player_league_position, player_target_hit, player_cup_stage, player_yellow_cards, player_red_cards, player_goals_conceded, player_goals_scored, player_interviews, player_penalties) players.append(new_player) st.success(f"{player_name} eklendi!") # Hesapla bölümü if st.button("Hesapla"): calculate_fair_play_points(players) calculate_goal_awards(players) apply_penalty_points(players) st.success("Hesaplamalar yapıldı ve ödüller verildi!") # DataFrame'i oluştur ve görüntüle df_players = create_dataframe(players) st.write(df_players) # Excel çıktısı if st.button("Excel İndir"): st.write("Excel İndiriliyor...") excel_data = df_players.to_excel(index=False, header=True) st.download_button(label="Excel İndir", data=excel_data, file_name='oyuncu_verileri.xlsx', mime='application/vnd.openxmlformats-officedocument.spreadsheetml.sheet')