File size: 1,992 Bytes
7d7c85c
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
import gradio as gr
import pandas as pd
from transformers import pipeline

# تحميل نموذج تلخيص النصوص باللغة العربية من Hugging Face
summarizer = pipeline("summarization", model="microsoft/mdeberta-v3-base")

# تحميل البيانات وتحليلها
def load_and_analyze(file):
    global df
    df = pd.read_csv(file.name)
    return f"تم تحميل البيانات بنجاح! عدد الصفوف: {df.shape[0]}, عدد الأعمدة: {df.shape[1]}"

# الرد على استفسارات المحلل
def answer_query(query):
    global df
    if df is None:
        return "❌ الرجاء تحميل ملف البيانات أولاً."
    
    query = query.lower()
    if "المتوسط" in query or "المعدل" in query:
        result = df.mean().to_string()
    elif "أكبر قيمة" in query or "القيمة العليا" in query:
        result = df.max().to_string()
    elif "أصغر قيمة" in query or "القيمة الدنيا" in query:
        result = df.min().to_string()
    elif "ملخص" in query:
        stats = df.describe().to_string()
        summary = summarizer(stats, max_length=100, do_sample=False)[0]['summary_text']
        result = f"📊 **ملخص البيانات:**\n{summary}"
    else:
        result = "❓ لم أفهم السؤال. حاول إعادة صياغته."
    
    return result

# إنشاء واجهة Gradio
with gr.Blocks() as app:
    gr.Markdown("## 🤖 Chatbot لمحللي البيانات")
    
    file_input = gr.File(label="📂 رفع ملف CSV")
    file_output = gr.Textbox(label="🔍 حالة البيانات")
    file_input.change(load_and_analyze, inputs=file_input, outputs=file_output)
    
    chat_input = gr.Textbox(label="💬 اسأل عن البيانات")
    chat_output = gr.Textbox(label="🤖 إجابة الذكاء الاصطناعي")
    chat_input.submit(answer_query, inputs=chat_input, outputs=chat_output)
    
    app.launch()