Asistente-13 / app.py
alexacido's picture
Upload 3 files
1682b9d verified
import gradio as gr
import pandas as pd
from pandasai import SmartDataframe
df_global = None
sdf = None
def cargar_csv(file):
global df_global, sdf
try:
df_global = pd.read_csv(file.name)
sdf = SmartDataframe(df_global, config={"enable_cache": False})
return f"Archivo cargado con éxito. Filas: {len(df_global)}, Columnas: {len(df_global.columns)}"
except Exception as e:
return f"Error al cargar el archivo: {str(e)}"
def responder_pregunta(pregunta):
global sdf
if sdf is None:
return "Primero debes cargar un archivo CSV."
try:
respuesta = sdf.chat(pregunta)
# Protección explícita contra errores de tipo booleano o vacío
if isinstance(respuesta, bool) or respuesta is None:
return "La pregunta no puede interpretarse correctamente sin un modelo LLM. Intenta otra más específica sobre columnas o datos."
return str(respuesta)
except Exception as e:
if "bool" in str(e) and "iterable" in str(e):
return "Error: La respuesta generada no es válida. Intenta otra pregunta o usa un modelo LLM si es necesario."
return f"Ocurrió un error al responder la pregunta: {str(e)}"
with gr.Blocks() as demo:
gr.Markdown("# Asistente CSV sin LLM (a prueba de errores)")
with gr.Row():
archivo = gr.File(label="Sube tu archivo CSV", file_types=[".csv"])
salida_carga = gr.Textbox(label="Resultado de carga")
boton_carga = gr.Button("Cargar CSV")
with gr.Row():
pregunta = gr.Textbox(label="Escribe tu pregunta sobre los datos")
salida_respuesta = gr.Textbox(label="Respuesta")
boton_pregunta = gr.Button("Responder")
boton_carga.click(cargar_csv, inputs=[archivo], outputs=[salida_carga])
boton_pregunta.click(responder_pregunta, inputs=[pregunta], outputs=[salida_respuesta])
if __name__ == "__main__":
demo.launch()