Для того чтобы настроить приложение, использующее библиотеку aiogram для работы с Telegram Bot API, чтобы оно реагировало только на отправляемые пользователем файлы и выводило `file_id`, вам необходимо создать обработчик событий (handler), который будет реагировать на сообщения с документами.
Для aiogram версии 3.4 процесс настройки может выглядеть следующим образом:
```python
import logging
from aiogram import Bot, Dispatcher, types, executor
API_TOKEN = 'ваш_токен_бота'
# Настройка логирования
logging.basicConfig(level=logging.INFO)
# Инициализация бота и диспетчера
bot = Bot(token=API_TOKEN)
dp = Dispatcher()
# Обработчик для документов
@dp.message_handler(content_types=types.ContentType.DOCUMENT)
async def document_message_handler(message: types.Message):
document = message.document
file_id = document.file_id
print(f"File ID: {file_id}")
# Тут можно добавить дополнительную логику,
# например, сохранить файл или отреагировать на сообщение
await message.reply("Спасибо за файл!")
if __name__ == '__main__':
# Запуск бота
executor.start_polling(dp)
```
В этом примере бот будет реагировать только на сообщения с документами. Когда пользователь отправляет файл, обработчик `document_message_handler` срабатывает, получает `file_id` из сообщения и выводит его в консоль. Также бот отправляет пользователю сообщение в ответ через метод `message.reply`.
Убедитесь, что вы заменили `'ваш_токен_бота'` на реальный токен вашего бота, полученный от @BotFather в Telegram.
Чтобы запустить бота, сохраните приведённый выше скрипт в файл (например, `bot.py`) и выполните его, используя интерпретатор Python.
Обратите внимание на то, что aiogram довольно часто обновляется, и если вы читаете это позже даты крайнего обновления знаний (апрель 2023), возможно, что в документации библиотеки появились изменения. Всегда рекомендуется проверять самую свежую документацию для получения актуальной информации и используемых методов.