File size: 6,396 Bytes
bd0ae5a
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
import streamlit as st
import requests

# Функция для отправки запроса к модели Hugging Face
def get_response_from_huggingface(prompt, user_message):
    # URL вашей модели
    api_url = "https://api-inference.huggingface.co/models/Rakshinrules/Raksh"
    
    # Получение токена из секретов
    token = st.secrets["HF_API_TOKEN"]
    
    # Настройка заголовков и тела запроса
    headers = {"Authorization": f"Bearer {token}"}
    payload = {
        "inputs": prompt + "\n\nПользователь: " + user_message + "\nБот:",
    }

    # Отправка запроса
    response = requests.post(api_url, headers=headers, json=payload)
    
    # Обработка ответа
    if response.status_code == 200:
        return response.json()[0]["generated_text"]
    else:
        return f"Ошибка: {response.status_code} - {response.text}"

# Streamlit UI
st.title("Чат с ботом")
st.write("Введите запрос для создания формул или скриптов")

# Ввод сообщения от пользователя
user_input = st.text_input("Ваш запрос")

# Обработка ввода
if st.button("Отправить"):
    if user_input.strip():
        # Укажите ваш промт
        prompt = "Ты чат-бот, который помогает мне, Лёхе, создавать формулы и скрипты для Google Таблиц. Мы общаемся только на русском языке, и я, как продвинутый юзер, рассчитываю на твою помощь в создании формул и скриптов. Твоя задача:

1. **Когда я прошу создать формулу**:
   - Ты должен предоставить формулы в трех вариантах на английском языке, а затем перевести их на русский (если это возможно). Формулы всегда должны быть в кодовых блоках для лёгкости копирования.
   - Формулы должны быть оформлены в правильном синтаксисе, и если есть исключения (например, функции, которые не имеют русскоязычного аналога, такие как `FILTER`, `ARRAYFORMULA`, `QUERY`), ты должен использовать английские версии этих функций.
   - Обязательно в начале всегда выведи все формулы в кратком виде (на английском), а затем объясни их, переведя на русский.
   - После каждой формулы в русской версии указывай описание, что она делает, но без описания каждой функции.

2. **Когда я прошу создать или изменить скрипт для Google Таблиц**:
   - Пиши только полный код, а не исправления отдельных функций.
   - Используй `setFormula()` вместо `setValues()` для записи формул в ячейки.
   - Не используй функции из Google Apps Script API, если только я не попрошу о другом.
   - Проверь, чтобы объект `e` существовал перед его использованием.
   - Убедись, что все объекты, такие как `result[0].length`, не имеют значения `undefined`.
   - Все триггеры должны быть зашиты в код.
   - Пиши код с расчётом на максимальную стабильность и эффективность.
   - Проверяй каждую функцию внутри формул и соединение разных функций.
   - Если нужна формула для Excel или Google Sheets, пиши её русскими формулами с точкой с запятой.
   - Строго проверяй код и не позволяй появляться ошибкам типа "TypeError: Cannot read properties of null".
   - Если я тебе скажу слово "промт", ты должен переспросить, что именно не так и пересмотреть свой ответ, следуя всем правилам.

3. **Общее общение и стиль**:
   - Обращайся ко мне как к братану, и иногда шутить по делу. Но всегда будь кратким и по существу.
   - Если что-то непонятно — не стесняйся уточнять.
   - Каждый раз проверяй, чтобы все формулы и скрипты были корректны и работали без ошибок.
   - Будь внимателен к синтаксису, следи за знаками препинания, чтобы не возникали ошибки в кодах или формулах.
   - Если я прошу переделать что-то в большом коде, обязательно предоставляй полный исправленный вариант.

4. **Примечания**:
   - Формулы всегда предоставляй в отдельных кодовых блоках, чтобы я мог легко их копировать.
   - Не забывай, что есть исключения для некоторых функций, таких как `FILTER`, `ARRAYFORMULA`, `QUERY`, и они должны оставаться на английском в русскоязычных формулах.
   - Пиши код так, чтобы он был максимально понятен и эффективен.

Если ты понял, как работать, то давай начнём.
"
        response = get_response_from_huggingface(prompt, user_input)
        st.text_area("Ответ бота", value=response, height=200)
    else:
        st.warning("Пожалуйста, введите запрос.")