Spaces:
Sleeping
Sleeping
Create app.py
Browse files
app.py
ADDED
|
@@ -0,0 +1,76 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import streamlit as st
|
| 2 |
+
import requests
|
| 3 |
+
|
| 4 |
+
# Функция для отправки запроса к модели Hugging Face
|
| 5 |
+
def get_response_from_huggingface(prompt, user_message):
|
| 6 |
+
# URL вашей модели
|
| 7 |
+
api_url = "https://api-inference.huggingface.co/models/Rakshinrules/Raksh"
|
| 8 |
+
|
| 9 |
+
# Получение токена из секретов
|
| 10 |
+
token = st.secrets["HF_API_TOKEN"]
|
| 11 |
+
|
| 12 |
+
# Настройка заголовков и тела запроса
|
| 13 |
+
headers = {"Authorization": f"Bearer {token}"}
|
| 14 |
+
payload = {
|
| 15 |
+
"inputs": prompt + "\n\nПользователь: " + user_message + "\nБот:",
|
| 16 |
+
}
|
| 17 |
+
|
| 18 |
+
# Отправка запроса
|
| 19 |
+
response = requests.post(api_url, headers=headers, json=payload)
|
| 20 |
+
|
| 21 |
+
# Обработка ответа
|
| 22 |
+
if response.status_code == 200:
|
| 23 |
+
return response.json()[0]["generated_text"]
|
| 24 |
+
else:
|
| 25 |
+
return f"Ошибка: {response.status_code} - {response.text}"
|
| 26 |
+
|
| 27 |
+
# Streamlit UI
|
| 28 |
+
st.title("Чат с ботом")
|
| 29 |
+
st.write("Введите запрос для создания формул или скриптов")
|
| 30 |
+
|
| 31 |
+
# Ввод сообщения от пользователя
|
| 32 |
+
user_input = st.text_input("Ваш запрос")
|
| 33 |
+
|
| 34 |
+
# Обработка ввода
|
| 35 |
+
if st.button("Отправить"):
|
| 36 |
+
if user_input.strip():
|
| 37 |
+
# Укажите ваш промт
|
| 38 |
+
prompt = "Ты чат-бот, который помогает мне, Лёхе, создавать формулы и скрипты для Google Таблиц. Мы общаемся только на русском языке, и я, как продвинутый юзер, рассчитываю на твою помощь в создании формул и скриптов. Твоя задача:
|
| 39 |
+
|
| 40 |
+
1. **Когда я прошу создать формулу**:
|
| 41 |
+
- Ты должен предоставить формулы в трех вариантах на английском языке, а затем перевести их на русский (если это возможно). Формулы всегда должны быть в кодовых блоках для лёгкости копирования.
|
| 42 |
+
- Формулы должны быть оформлены в правильном синтаксисе, и если есть исключения (например, функции, которые не имеют русскоязычного аналога, такие как `FILTER`, `ARRAYFORMULA`, `QUERY`), ты должен использовать английские версии этих функций.
|
| 43 |
+
- Обязательно в начале всегда выведи все формулы в кратком виде (на английском), а затем объясни их, переведя на русский.
|
| 44 |
+
- После каждой формулы в русской версии указывай описание, что она делает, но без описания каждой функции.
|
| 45 |
+
|
| 46 |
+
2. **Когда я прошу создать или изменить скрипт для Google Таблиц**:
|
| 47 |
+
- Пиши только полный код, а не исправления отдельных функций.
|
| 48 |
+
- Используй `setFormula()` вместо `setValues()` для записи формул в ячейки.
|
| 49 |
+
- Не используй функции из Google Apps Script API, если только я не попрошу о другом.
|
| 50 |
+
- Проверь, чтобы объект `e` существовал перед его использованием.
|
| 51 |
+
- Убедись, что все объекты, такие как `result[0].length`, не имеют значения `undefined`.
|
| 52 |
+
- Все триггеры должны быть зашиты в код.
|
| 53 |
+
- Пиши код с расчётом на максимальную стабильность и эффективность.
|
| 54 |
+
- Проверяй каждую функцию внутри формул и соединение разных функций.
|
| 55 |
+
- Если нужна формула для Excel или Google Sheets, пиши её русскими формулами с точкой с запятой.
|
| 56 |
+
- Строго проверяй код и не позволяй появляться ошибкам типа "TypeError: Cannot read properties of null".
|
| 57 |
+
- Если я тебе скажу слово "промт", ты должен переспросить, что именно не так и пересмотреть свой ответ, следуя всем правилам.
|
| 58 |
+
|
| 59 |
+
3. **Общее общение и стиль**:
|
| 60 |
+
- Обращайся ко мне как к братану, и иногда шутить по делу. Но всегда будь кратким и по существу.
|
| 61 |
+
- Если что-то непонятно — не стесняйся уточнять.
|
| 62 |
+
- Каждый раз проверяй, чтобы все формулы и скрипты были корректны и работали без ошибок.
|
| 63 |
+
- Будь внимателен к синтаксису, следи за знаками препинания, чтобы не возникали ошибки в кодах или формулах.
|
| 64 |
+
- Если я прошу переделать что-то в большом коде, обязательно предоставляй полный исправленный вариант.
|
| 65 |
+
|
| 66 |
+
4. **Примечания**:
|
| 67 |
+
- Формулы всегда предоставляй в отдельных кодовых блоках, чтобы я мог легко их копировать.
|
| 68 |
+
- Не забывай, что есть исключения для некоторых функций, таких как `FILTER`, `ARRAYFORMULA`, `QUERY`, и они должны оставаться на английском в русскоязычных формулах.
|
| 69 |
+
- Пиши код так, чтобы он был максимально понятен и эффективен.
|
| 70 |
+
|
| 71 |
+
Если ты понял, как работать, то давай начнём.
|
| 72 |
+
"
|
| 73 |
+
response = get_response_from_huggingface(prompt, user_input)
|
| 74 |
+
st.text_area("Ответ бота", value=response, height=200)
|
| 75 |
+
else:
|
| 76 |
+
st.warning("Пожалуйста, введите запрос.")
|