Форум программистов, компьютерный форум, киберфорум
Python
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/34: Рейтинг темы: голосов - 34, средняя оценка - 4.71
0 / 0 / 0
Регистрация: 23.10.2015
Сообщений: 2

Python telebot и sqlite3 (Recursive use of cursors not allowed)

17.02.2018, 15:42. Показов 6755. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть телеграм бот, который отправляет сообщения, получая информацию из бд sqlite3:

Python
1
2
3
4
5
6
@bot.message_handler(regexp=config[language]['cat_phones'])
def handle_text(message):
    cursor.execute('SELECT * FROM lots')
    for row in cursor:
        bot.send_message(message.from_user.id, '{0}\n{1}\n<b> {2:,} {3}</b>\n<b> {4:,} {3}</b>'.format(
        row[3], row[5], row[8], row[1], row[8]/100*20), parse_mode='HTML')
когда 2 человека одновременно жмут эту кнопку, то возникает ошибка `Recursive use of cursors not allowed`
И вот, только перед запуском бота я узнал, что sqlite3 не поддерживает многопточность.

Вопросы:
  1. Каким образом можно решить эту проблему не переходя на другой тип бд?
  2. Какие бд поддерживают многопоточность?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
17.02.2018, 15:42
Ответы с готовыми решениями:

Как вставить словарь в базу данных sqlite3 telebot python?
Всем привет! Начал писать telegram бота (библиотека telebot), который должен сохранять заказы в базу данных SQLite3. Происходит это так:...

Разссылка сообщений пользователям таблицы sqlite3 в telebot
Есть список ID пользователей в sqlite3, один из пользователей, например, что-то написал, сообщение должны прийти всем пользователям, что...

Постоянная ошибка AttributeError: module 'telebot' has no attribute 'Telebot'. Did you mean: 'TeleBot'?
Учусь делать бота в телегу Вылезла такая ошибка AttributeError: module 'telebot' has no attribute 'Telebot'. Did you mean: 'TeleBot'? ...

3
1741 / 913 / 480
Регистрация: 05.12.2013
Сообщений: 3,074
17.02.2018, 21:26
Можно сначала добавлять запросы в очередь и выполнять по одному
0
Эксперт по компьютерным сетям
 Аватар для Jabbson
5907 / 3359 / 1036
Регистрация: 03.11.2009
Сообщений: 10,008
17.02.2018, 23:32
locks?
0
963 / 718 / 276
Регистрация: 10.12.2016
Сообщений: 1,764
18.02.2018, 02:13
Цитата Сообщение от Pryan1check Посмотреть сообщение
Каким образом можно решить эту проблему не переходя на другой тип бд?
Какие бд поддерживают многопоточность?
1. можно так
Python
1
2
3
4
5
try:
    cursor.execute('SELECT * FROM lots')
    #....
except:
    print('please wait,  try later...')
2. любая клиент-серверная
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
18.02.2018, 02:13
Помогаю со студенческими работами здесь

Python telebot не отправляется картинка
fpath = f&quot;{data}.jpg&quot; with open(fpath, 'rb') as myfile: fstr = myfile.read() print(img_path) ...

Не могу установить модуль Telebot на python 3.6.4
Не могу установить модуль Telebot на python 3, делал уже через pip и в ручную пытался. С простейшей задачей справиться не могу, помогите...

Телеграмм бот / telebot / python / ошибка 400
При запуске бота сообщением Test, иногда он останавливается и выдает ошибку: &quot;2022-03-25 08:05:30,414 (__init__.py:688 MainThread)...

AttributeError: partially initialized module 'telebot' has no attribute 'TeleBot' (most likely due to a circular import)
Доброго времени суток! Учусь писать ботов для телеграма. Всё сделал правильно. Модуль установлен но вылетает следующая ошибка. $ python...

Как сделать кнопку назад в боте Telegram на Python (TeleBot)?
Мне нужно, чтобы при выборе своего возраста была возможность вернуться назад в главное меню назад где выбираешь язык. import telebot ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru