Spaces:
Sleeping
Sleeping
Update app.py
Browse files
app.py
CHANGED
@@ -4,8 +4,7 @@ from transformers import pipeline
|
|
4 |
import os
|
5 |
from supabase import create_client, Client
|
6 |
from datetime import datetime
|
7 |
-
import
|
8 |
-
import tempfile
|
9 |
|
10 |
# Add your AssemblyAI API key as Environment Variable
|
11 |
aai.settings.api_key = os.environ['Assembly']
|
@@ -140,28 +139,43 @@ def save_answers(*args):
|
|
140 |
print(f"Error inserting data into Supabase: {e}")
|
141 |
return f"Error saving answers: {e}"
|
142 |
|
143 |
-
|
144 |
-
|
145 |
-
|
146 |
-
|
147 |
-
|
148 |
-
|
149 |
-
|
150 |
-
|
151 |
-
|
152 |
-
|
153 |
-
|
154 |
-
|
155 |
-
|
156 |
-
|
157 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
158 |
|
159 |
# Create the Gradio interface
|
160 |
with gr.Blocks() as demo:
|
161 |
gr.Markdown("# OHA Form Filler App")
|
162 |
-
download_button = gr.Button("Download CSV", elem_id="download_button")
|
163 |
audio_input = gr.Audio(type="filepath", label="Record your audio", elem_id="audio_input")
|
164 |
transcribe_button = gr.Button("Transcribe and Generate Form", elem_id="transcribe_button")
|
|
|
165 |
|
166 |
with gr.Row(elem_id="textboxes_row"):
|
167 |
with gr.Column():
|
@@ -174,7 +188,7 @@ with gr.Blocks() as demo:
|
|
174 |
|
175 |
transcribe_button.click(fn=main, inputs=audio_input, outputs=textboxes_left + textboxes_right)
|
176 |
submit_button.click(fn=save_answers, inputs=textboxes_left + textboxes_right, outputs=output_html)
|
177 |
-
download_button.click(fn=
|
178 |
|
179 |
-
#
|
180 |
demo.launch(share=True)
|
|
|
4 |
import os
|
5 |
from supabase import create_client, Client
|
6 |
from datetime import datetime
|
7 |
+
import csv
|
|
|
8 |
|
9 |
# Add your AssemblyAI API key as Environment Variable
|
10 |
aai.settings.api_key = os.environ['Assembly']
|
|
|
139 |
print(f"Error inserting data into Supabase: {e}")
|
140 |
return f"Error saving answers: {e}"
|
141 |
|
142 |
+
# Function to download table as CSV
|
143 |
+
def download_table_to_csv():
|
144 |
+
# Fetch data from Supabase table
|
145 |
+
response = supabase.table("oral_health_assessments").select("*").execute()
|
146 |
+
|
147 |
+
# Check if data is available
|
148 |
+
if not response.data:
|
149 |
+
print("No data found in the table.")
|
150 |
+
return "No data found in the table."
|
151 |
+
|
152 |
+
data = response.data
|
153 |
+
|
154 |
+
# Prepare CSV data
|
155 |
+
csv_data = []
|
156 |
+
|
157 |
+
# Add header row
|
158 |
+
if len(data) > 0:
|
159 |
+
csv_data.append(data[0].keys())
|
160 |
+
|
161 |
+
# Add data rows
|
162 |
+
for row in data:
|
163 |
+
csv_data.append(row.values())
|
164 |
+
|
165 |
+
# Save CSV data to file
|
166 |
+
with open("oral_health_assessments.csv", "w", newline='') as f:
|
167 |
+
writer = csv.writer(f)
|
168 |
+
writer.writerows(csv_data)
|
169 |
+
|
170 |
+
print(f"Downloaded table 'oral_health_assessments' to 'oral_health_assessments.csv'")
|
171 |
+
return "Table downloaded successfully as 'oral_health_assessments.csv'"
|
172 |
|
173 |
# Create the Gradio interface
|
174 |
with gr.Blocks() as demo:
|
175 |
gr.Markdown("# OHA Form Filler App")
|
|
|
176 |
audio_input = gr.Audio(type="filepath", label="Record your audio", elem_id="audio_input")
|
177 |
transcribe_button = gr.Button("Transcribe and Generate Form", elem_id="transcribe_button")
|
178 |
+
download_button = gr.Button("Download as CSV", elem_id="download_button")
|
179 |
|
180 |
with gr.Row(elem_id="textboxes_row"):
|
181 |
with gr.Column():
|
|
|
188 |
|
189 |
transcribe_button.click(fn=main, inputs=audio_input, outputs=textboxes_left + textboxes_right)
|
190 |
submit_button.click(fn=save_answers, inputs=textboxes_left + textboxes_right, outputs=output_html)
|
191 |
+
download_button.click(fn=download_table_to_csv, outputs=output_html)
|
192 |
|
193 |
+
# Launch the app
|
194 |
demo.launch(share=True)
|