drmurataltun's picture
Update app.py
6ab7e13 verified
import gradio as gr
import pandas as pd
from pycaret.classification import setup, compare_models, pull
# Sütunları ve veri setini alma fonksiyonu
def get_columns(dosya):
if dosya is None:
return gr.update(choices=[]), gr.update(choices=[]), gr.update(choices=[]), pd.DataFrame()
data = pd.read_csv(dosya.name)
kolonlar = data.columns.tolist()
return (
gr.update(choices=kolonlar), # Hedef sütun seçenekleri
gr.update(choices=kolonlar), # Sayısal sütunlar
gr.update(choices=kolonlar), # Kategorik sütunlar
data.head() # Veri seti ön izlemesi
)
# Otomatik modelleme fonksiyonu
def otoml_islemi(dosya, hedef_sutun, sayisal_sutunlar, kategorik_sutunlar,
sayisal_imputasyon, kategorik_imputasyon, normalize, remove_outliers, ignore_sutunlar):
# Veri setini yükleyin
data = pd.read_csv(dosya.name)
# PyCaret kurulumunu başlatın
s = setup(
data,
target=hedef_sutun,
numeric_features=sayisal_sutunlar if sayisal_sutunlar else None,
categorical_features=kategorik_sutunlar if kategorik_sutunlar else None,
ignore_features=ignore_sutunlar if ignore_sutunlar else None,
numeric_imputation=sayisal_imputasyon,
categorical_imputation=kategorik_imputasyon,
normalize=normalize,
remove_outliers=remove_outliers,
)
# Modelleri karşılaştırın ve en iyisini seçin
en_iyi_model = compare_models()
# Model değerlendirme sonuçlarını alın
degerlendirme = pull()
return degerlendirme
# Gradio arayüzü
with gr.Blocks() as demo:
gr.Markdown("# PyCaret ile AutoML Arayüzü")
with gr.Row():
dosya = gr.File(label="Veri Seti (CSV)")
with gr.Row():
hedef_sutun = gr.Dropdown(label="Hedef Sütun Adı", choices=[])
with gr.Row():
sayisal_sutunlar = gr.CheckboxGroup(label="Sayısal Sütunlar", choices=[])
kategorik_sutunlar = gr.CheckboxGroup(label="Kategorik Sütunlar", choices=[])
ignore_sutunlar = gr.CheckboxGroup(label="Görmezden Gelinecek Sütunlar", choices=[])
with gr.Row():
sayisal_imputasyon = gr.Dropdown(choices=['mean', 'median', 'zero'], label="Sayısal İmputasyon Yöntemi", value='mean')
kategorik_imputasyon = gr.Dropdown(choices=['mode', 'constant'], label="Kategorik İmputasyon Yöntemi", value='mode')
with gr.Row():
normalize = gr.Checkbox(label="Normalize Et", value=False)
remove_outliers = gr.Checkbox(label="Aykırı Değerleri Kaldır", value=False)
buton = gr.Button("Otomatik Modelleme Başlat")
output = gr.Dataframe(label="Model Değerlendirme Sonuçları")
preview = gr.Dataframe(label="Veri Seti Ön İzlemesi")
# Dosya yüklendiğinde sütunları ve veri setini al
dosya.change(
fn=get_columns,
inputs=dosya,
outputs=[hedef_sutun, sayisal_sutunlar, kategorik_sutunlar, preview]
)
# Modelleme butonuna tıklandığında işlemi başlat
buton.click(
fn=otoml_islemi,
inputs=[dosya, hedef_sutun, sayisal_sutunlar, kategorik_sutunlar,
sayisal_imputasyon, kategorik_imputasyon, normalize, remove_outliers, ignore_sutunlar],
outputs=output
)
demo.launch(share=True)