Я пытаюсь создать набор наклеек, используя изображения, отправленные пользователем на мой бот. У меня есть следующий код:
MY_USER_ID = "MyFakeUserId"
MY_TOKEN = "MyFakeToken"
import logging
logging.basicConfig(format='%(asctime)s - %(name)s - %(levelname)s - %(message)s', level=logging.INFO)
from telegram.ext import Updater, MessageHandler, Filters, CommandHandler
updater = Updater(token=MY_TOKEN, use_context=True)
updater.start_polling()
dispatcher = updater.dispatcher
def create_sticker_set(update, context):
update_dict = update.to_dict()
sticker_file_id = update_dict["message"]["photo"][-1]["file_id"]
print("sticker_file_id=", sticker_file_id)
# sticker_file = context.bot.upload_sticker_file(MY_USER_ID, sticker_file_id)
context.bot.create_new_sticker_set(MY_USER_ID, "lala_by_my_fake_bot", "lala", sticker_file_id, "???")
msghandler = MessageHandler(Filters.photo, create_sticker_set)
dispatcher.add_handler(msghandler)
Я отправляю в чат картинку в формате png размером 512 x 512 пикселей. И этот код не работает.
Я получаю следующее сообщение в своих журналах:
sticker_file_id= AgACAgQAAx0CUsT2sgADyF5SvWsoQ9ZTjw436M0nntrlkUtkAALjsTEb9W2ZUg-6JVL7B5D8wjq2GwAEAQADAgADeAADyYoDAAEYBA
2020-02-23 18:59:07,376 - telegram.ext.dispatcher - ERROR - No error handlers are registered, logging exception.
Traceback (most recent call last):
File "/usr/local/lib/python3.7/site-packages/telegram/ext/dispatcher.py", line 390, in process_update
handler.handle_update(update, self, check, context)
File "/usr/local/lib/python3.7/site-packages/telegram/ext/handler.py", line 117, in handle_update
return self.callback(update, context)
File "testing.py", line 58, in callback
context.bot.create_new_sticker_set(MY_USER_ID, "facebooklala_by_ibodi_bot", "FacebookLala", sticker_file_id, "???")
File "</usr/local/lib/python3.7/site-packages/decorator.py:decorator-gen-58>", line 2, in create_new_sticker_set
File "/usr/local/lib/python3.7/site-packages/telegram/bot.py", line 67, in decorator
result = func(*args, **kwargs)
File "/usr/local/lib/python3.7/site-packages/telegram/bot.py", line 3298, in create_new_sticker_set
result = self._request.post(url, data, timeout=timeout)
File "/usr/local/lib/python3.7/site-packages/telegram/utils/request.py", line 334, in post
**urlopen_kwargs)
File "/usr/local/lib/python3.7/site-packages/telegram/utils/request.py", line 245, in _request_wrapper
raise BadRequest(message)
telegram.error.BadRequest: Type of file mismatch
Я не вижу другого выхода, кроме как загрузить изображение и загрузить его снова. Как это:
def create_sticker_set(update, context):
update_dict = update.to_dict()
sticker_file_id = update_dict["message"]["photo"][-1]["file_id"]
print("sticker_file_id=", sticker_file_id)
# sticker_file = context.bot.upload_sticker_file(MY_USER_ID, sticker_file_id)
file = context.bot.get_file(update_dict["message"]["photo"][-1]["file_id"])
filename = file.download()
context.bot.create_new_sticker_set(MY_USER_ID, "lala_by_ibodi_bot", "lala", open(filename, "rb"), "???")