Задать вопрос
@DMihey

Телеграмм бот не отправляет аудиофайл?

Есть такой кусок кода:

@bot.callback_query_handler(func=lambda call: True)
def callback_inline(call):
		message = call.message

		if call.data == 'Go_game':
			bot.send_message(message.chat.id, 'Для полного погружения реклмендуем играть с музыкой:')
			audio = open('воздух.wav', 'rb')
			bot.send_audio(message.chat.id, audio)
			audio.close()


При нажатии на кнопку отправляется сообщение при помощи sent_message, но sent_audio не отравляет трек. Небольшое время висит, а потом выдаёт ошибку:
spoiler
Traceback (most recent call last):
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\urllib3\connectionpool.py", line 789, in urlopen
    response = self._make_request(
               ^^^^^^^^^^^^^^^^^^^
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\urllib3\connectionpool.py", line 495, in _make_request
    conn.request(
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\urllib3\connection.py", line 412, in request
    self.send(chunk)
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\http\client.py", line 1055, in send
    self.sock.sendall(data)
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\ssl.py", line 1211, in sendall
    v = self.send(byte_view[count:])
        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\ssl.py", line 1180, in send
    return self._sslobj.write(data)
           ^^^^^^^^^^^^^^^^^^^^^^^^
TimeoutError: The write operation timed out

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\requests\adapters.py", line 667, in send
    resp = conn.urlopen(
           ^^^^^^^^^^^^^
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\urllib3\connectionpool.py", line 843, in urlopen
    retries = retries.increment(
              ^^^^^^^^^^^^^^^^^^
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\urllib3\util\retry.py", line 474, in increment
    raise reraise(type(error), error, _stacktrace)
          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\urllib3\util\util.py", line 38, in reraise
    raise value.with_traceback(tb)
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\urllib3\connectionpool.py", line 789, in urlopen
    response = self._make_request(
               ^^^^^^^^^^^^^^^^^^^
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\urllib3\connectionpool.py", line 495, in _make_request
    conn.request(
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\urllib3\connection.py", line 412, in request
    self.send(chunk)
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\http\client.py", line 1055, in send
    self.sock.sendall(data)
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\ssl.py", line 1211, in sendall
    v = self.send(byte_view[count:])
        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\ssl.py", line 1180, in send
    return self._sslobj.write(data)
           ^^^^^^^^^^^^^^^^^^^^^^^^
urllib3.exceptions.ProtocolError: ('Connection aborted.', TimeoutError('The write operation timed out'))

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "E:\содержимое\проекты\бот-портфолио\init.py", line 72, in <module>
    bot.polling()
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\telebot\__init__.py", line 1189, in polling
    self.__threaded_polling(non_stop=non_stop, interval=interval, timeout=timeout, long_polling_timeout=long_polling_timeout,
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\telebot\__init__.py", line 1264, in __threaded_polling
    raise e
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\telebot\__init__.py", line 1226, in __threaded_polling
    self.worker_pool.raise_exceptions()
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\telebot\util.py", line 150, in raise_exceptions
    raise self.exception_info
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\telebot\util.py", line 93, in run
    task(*args, **kwargs)
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\telebot\__init__.py", line 8822, in _run_middlewares_and_handler
    result = handler['function'](message)
             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "E:\содержимое\проекты\бот-портфолио\init.py", line 52, in callback_inline
    bot.send_audio(message.chat.id, audio)
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\telebot\__init__.py", line 2382, in send_audio
    apihelper.send_audio(
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\telebot\apihelper.py", line 990, in send_audio
    return _make_request(token, method_url, params=payload, files=files, method='post')
           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\telebot\apihelper.py", line 162, in _make_request
    result = _get_req_session().request(
             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\requests\sessions.py", line 589, in request
    resp = self.send(prep, **send_kwargs)
           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\requests\sessions.py", line 703, in send
    r = adapter.send(request, **kwargs)
        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "C:\Users\Nik Hette\AppData\Local\Programs\Python\Python312\Lib\site-packages\requests\adapters.py", line 682, in send
    raise ConnectionError(err, request=request)
requests.exceptions.ConnectionError: ('Connection aborted.', TimeoutError('The write operation timed out'))
[Finished in 19.6s]
  • Вопрос задан
  • 45 просмотров
Подписаться 1 Средний 2 комментария
Пригласить эксперта
Ответы на вопрос 1
suprunchuk
@suprunchuk
Чтобы бот не падал при ошибке, добавьте try-except:

@bot.callback_query_handler(func=lambda call: True)
def callback_inline(call):
    message = call.message
    if call.data == 'Go_game':
        bot.send_message(message.chat.id, 'Для полного погружения реклмендуем играть с музыкой:')
        try:
            with open('воздух.wav', 'rb') as audio:
                bot.send_audio(message.chat.id, audio, timeout=60)
        except Exception as e:
            bot.send_message(message.chat.id, f'Ошибка при отправке аудио: {str(e)}')
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы