Spaces:
Sleeping
Sleeping
File size: 4,154 Bytes
a1e0a61 4c35ea4 a1e0a61 |
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 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 |
import os
import streamlit as st
import google.generativeai as genai
# TERMINATOR
error_flag = False # Global variable to track error display
def generate_response(cleaned_input, model):
global error_flag # Use the global error_flag variable
try:
# Generate response using the model
response = model.generate_content(cleaned_input, stream=True)
# Display the generated response
full_response = ""
for chunk in response:
full_response += chunk.text
return full_response.encode().decode('utf-8')
except Exception as e:
error_message = str(e)
if "text must be a valid text with maximum 5000 character" in error_message and not error_flag:
error_response = ("The question you are asking may go against Google GEMINI policies: WiseOracle"
"Please reformulate your question without forbidden topics or ask something else. "
"For more information, see: https://policies.google.com/terms/generative-ai/use-policy "
)
st.error(error_response)
error_flag = True # Set the error_flag to True after displaying the error message
return error_response
else:
error_response = f"Error: {error_message}\nSorry, I am an artificial intelligence that is still in development and is in alpha phase. At the moment, I cannot answer your question properly, but in the future, I will be able to do so."
st.error(error_response)
return error_response
# Aplicación Streamlit
def principal():
st.title("Formateador de Entrevistas")
genai.configure(api_key='AIzaSyCVqyQJSEN3vZcYRmCogVmHxlmYkzCUxdQ') # Replace with your Google GEMINI API key
# Choose the Gemini model
model = genai.GenerativeModel('gemini-pro')
# Cargador de archivos para el archivo .txt
archivo_cargado = st.file_uploader("Cargar un archivo .txt", type=["txt"])
if archivo_cargado is not None:
# Lee el contenido del archivo cargado
contenido = archivo_cargado.read()
# Botón para iniciar el formateo
if st.button("Iniciar Formateo"):
st.info("Formateo en progreso...")
# Divide el contenido en chunks de 1500 palabras
tamano_chunk = 1500
chunks = [contenido[i:i + tamano_chunk] for i in range(0, len(contenido), tamano_chunk)]
# Inicializa la barra de progreso
barra_progreso_chunks = st.progress(0)
# Procesa cada chunk y muestra la salida formateada
salida_formateada = ""
for i, chunk in enumerate(chunks):
respuesta_bot = generate_response(
f"No hay comentarios ni indicaciones. Simplemente sigue las instrucciones: lee línea por línea, frase por frase, identifica y reconoce los roles del entrevistador y el entrevistado en el siguiente texto de un segmento de entrevista, y formatea la salida como ese segmento de entrevista con etiquetas precediendo cada línea, palabra o frase con etiquetas de entrevistador y entrevistado. Presenta el mismo orden de desarrollo del segmento de entrevista con un salto de línea entre cada uno. Etiqueta cada palabra, línea, frase o párrafo según corresponda: {chunk}",
model
)
# Agrega la respuesta formateada a la salida
salida_formateada += respuesta_bot + "\n"
# Actualiza la barra de progreso
barra_progreso_chunks.progress((i + 1) / len(chunks))
# Muestra la salida formateada
st.success("Formateo completado")
st.text_area("Segmento de Entrevista Formateado:", salida_formateada)
# Botón para descargar la respuesta formateada
download_button = st.download_button(
label="Descargar Respuesta",
data=salida_formateada,
file_name="respuesta_formateada.txt",
key="download_button"
)
if __name__ == "__main__":
principal() |