M3zzYL commited on
Commit
035997c
·
verified ·
1 Parent(s): edb8e50

Delete app.py

Browse files
Files changed (1) hide show
  1. app.py +0 -84
app.py DELETED
@@ -1,84 +0,0 @@
1
- import gradio as gr
2
- import sqlite3
3
- import pandas as pd
4
- import plotly.express as px
5
- import random
6
- import json
7
- import os
8
- from datetime import datetime
9
- from transformers import pipeline
10
-
11
- def init_db():
12
- conn = sqlite3.connect('faithpath.db')
13
- cursor = conn.cursor()
14
- cursor.execute('''
15
- CREATE TABLE IF NOT EXISTS journal_entries (
16
- id INTEGER PRIMARY KEY AUTOINCREMENT, date TEXT, entry_text TEXT,
17
- detected_emotion TEXT, mission_source TEXT, mission_text TEXT, city TEXT
18
- )
19
- ''')
20
- conn.commit(); conn.close()
21
-
22
- init_db()
23
- sentiment_analyzer = pipeline('sentiment-analysis', model='savasy/bert-base-turkish-sentiment-cased')
24
-
25
- with open('faith_library_final_v56.json', 'r', encoding='utf-8') as f:
26
- faith_library = json.load(f)
27
-
28
- def semantic_bridge_engine(metin):
29
- text_lower = metin.lower()
30
- exclusive_logic = {
31
- 'öfke_ve_gerginlik': ['sabrımın son kertesindeyim', 'nevrim döndü', 'parlamamak', 'zor tutuyorum'],
32
- 'şükran_ve_minnet': ['secde-i şükran', 'hamd etsek az', 'minnettarım', 'allah bin bereket'],
33
- 'sabır_ve_metanet': ['bağrıma taş bastım', 'isyan etmeksizin', 'dişini sıkıp', 'sabır taşı'],
34
- 'cömertlik_ve_paylaşma': ['rızkı paylaştıkça', 'ihtiyacı olana', 'gönlümüzü açtık', 'infak etmek', 'sadaka vermek', 'ikramda bulunmak']
35
- }
36
- for cat, words in exclusive_logic.items():
37
- if any(w in text_lower for w in words): return cat, random.choice(faith_library.get(cat, []))
38
- bert_res = sentiment_analyzer(metin)[0]
39
- cat = 'mutluluk_ve_huzur' if bert_res['label'] == 'positive' else 'hüzün_ve_keder'
40
- return cat, random.choice(faith_library.get(cat, []))
41
-
42
- def process_entry_user(text):
43
- if len(text.strip()) < 5: return "Hata: Metin çok kısa."
44
- cat, mission = semantic_bridge_engine(text)
45
- conn = sqlite3.connect('faithpath.db')
46
- conn.execute('INSERT INTO journal_entries (date, entry_text, detected_emotion, mission_source, mission_text, city) VALUES (?,?,?,?,?,?)',
47
- (datetime.now().strftime('%Y-%m-%d %H:%M:%S'), text, cat, mission['kaynak'], mission['metin'], 'Web'))
48
- conn.commit(); conn.close()
49
- return f"""<div style='padding:20px; background:#0f172a; border-radius:10px; color:white;'>
50
- <h3 style='color:#10b981;'>Manevi Rehber</h3>
51
- <p><i>"{mission['metin']}"</i></p>
52
- <p align='right'>- {mission['kaynak']}</p>
53
- <hr>
54
- <p style='color:#fde047;'><b>🎯 Kalp Görevi:</b> {mission.get('rehber_mesaji', 'Ailenize vakit ayırın.')}</p>
55
- </div>"""
56
-
57
- def get_admin_content(password):
58
- if password != 'Enes.13112006': return gr.update(visible=False), None, None, "Hata!"
59
- conn = sqlite3.connect('faithpath.db')
60
- df = pd.read_sql_query('SELECT * FROM journal_entries', conn)
61
- conn.close()
62
- if df.empty: return gr.update(visible=True), None, None, "Henüz kayıt yok."
63
-
64
- fig_pie = px.pie(df, names='detected_emotion', title='Duygu Dağılımı', template='plotly_dark')
65
-
66
- # TARİH FORMATI DÜZENLEMESİ: DD/MM/YYYY
67
- df['date_dt'] = pd.to_datetime(df['date'])
68
- trend_df = df.groupby(df['date_dt'].dt.date).size().reset_index(name='Sayi')
69
- fig_line = px.line(trend_df, x='date_dt', y='Sayi', title='Kayıt Trendi', template='plotly_dark')
70
- fig_line.update_xaxes(tickformat="%d/%m/%Y")
71
-
72
- table_html = df[['date', 'entry_text', 'detected_emotion']].to_html(classes='table table-dark', index=False)
73
- return gr.update(visible=True), fig_pie, fig_line, f"### Kayıtlar\n{table_html}"
74
-
75
- with gr.Blocks() as demo:
76
- with gr.Tab('Asistan'):
77
- txt = gr.Textbox(lines=5); btn = gr.Button('Analiz'); out = gr.HTML(); btn.click(process_entry_user, txt, out)
78
- with gr.Tab('Admin'):
79
- pwd = gr.Textbox(type='password'); lbtn = gr.Button('Giriş'); zone = gr.Column(visible=False); plt1 = gr.Plot(); plt2 = gr.Plot(); stat = gr.HTML()
80
- with zone:
81
- with gr.Row(): plt1; plt2
82
- stat
83
- lbtn.click(get_admin_content, pwd, [zone, plt1, plt2, stat])
84
- demo.launch()