@Maks_432
Начинающий программист(нет)

Как добавить парсер в дискорд бот?

Захотел сделать своего дискорд-бота, и уже добавил одну функцию которая выдает роли при реакции на сообщение, но хочу добавить ещё функцию, которая бы по команде от человека выдавала бы скидки на некоторые игры в стиме. Вот собственно мой код, главная проблема в том, что он ничего не выдаёт при команде.
import discord
from discord import utils
from bs4 import BeautifulSoup
import requests
import rolescfgcom as config
#ВОТ САМ ПАРСЕР
url = 'https://store.steampowered.com/specials/?l=russian#p=0&tab=TopSellers'

response = requests.get(url=url).text

#with open('index.html', 'w', encoding='utf-8') as file:
    #file.write(response)

soup = BeautifulSoup(response, 'lxml')

all_games = soup.find_all('a', class_='tab_item')

result_list = []

for item in all_games:
    name = item.find(class_='tab_item_name').text.strip()
    price_final = item.find(class_='discount_final_price').text.strip()
    try:
        sale = item.find('div', class_='discount_pct').text.strip()
    except:
        sale = 'отсутствует'

    result_list.append({
        'name': name,
        'price': price_final,
        'sale': sale
    })
    
#for item in result_list:
    #n = print(item['name'])
    #p = print(item['price'])
    #s = print(item['sale'])
    #hz = print('-------------------')

intents = discord.Intents.all()
intents.members = True
 
client = discord.Client()

class MyClient(discord.Client):
    async def on_ready():
         print('We have logged in as {0.user}'.format(client))
 
    async def on_raw_reaction_add(self, payload):
        if payload.message_id == config.POST_ID:
            channel = self.get_channel(payload.channel_id) # получаем объект канала
            message = await channel.fetch_message(payload.message_id) # получаем объект сообщения
            member = utils.get(message.guild.members, id=payload.user_id) # получаем объект пользователя который поставил реакцию
 
            try:
                emoji = str(payload.emoji) # эмоджик который выбрал юзер
                role = utils.get(message.guild.roles, id=config.ROLES[emoji]) # объект выбранной роли (если есть)
            
                if(len([i for i in member.roles if i.id not in config.EXCROLES]) <= config.MAX_ROLES_PER_USER):
                    await member.add_roles(role)
                    print('[SUCCESS] User {0.display_name} has been granted with role {1.name}'.format(member, role))
                else:
                    await message.remove_reaction(payload.emoji, member)
                    print('[ERROR] Too many roles for user {0.display_name}'.format(member))
            
            except KeyError as e:
                print('[ERROR] KeyError, no role found for ' + emoji)
            except Exception as e:
                print(repr(e))
 
    async def on_raw_reaction_remove(self, payload):
        channel = self.get_channel(payload.channel_id) # получаем объект канала
        message = await channel.fetch_message(payload.message_id) # получаем объект сообщения
        member = utils.get(message.guild.members, id=payload.user_id) # получаем объект пользователя который поставил реакцию
 
        try:
            emoji = str(payload.emoji) # эмоджик который выбрал юзер
            role = utils.get(message.guild.roles, id=config.ROLES[emoji]) # объект выбранной роли (если есть)
 
            await member.remove_roles(role)
            print('[SUCCESS] Role {1.name} has been remove for user {0.display_name}'.format(member, role))
 
        except KeyError as e:
            print('[ERROR] KeyError, no role found for ' + emoji)
        except Exception as e:
            print(repr(e))
  
    async def on_message(message):
        if message.author == client.user:
            return
    # А ВОТ САМА ФУНКЦИЯ С ПОМОЩЬЮ КОТОРОЙ БОТ БЫ ВЫДАВАЛ БЫ СКИДКИ
        if message.content.startswith('СКИДКУ!'):
            await message.channel.send(for item in result_list:
                                           n = print(item['name'])
                                           p = print(item['price'])
                                           s = print(item['sale'])
                                           hz = print('-------------------')
                                                                    

client = discord.Client(intents=intents)
 
# RUN
client = MyClient(intents = discord.Intents.all())
client.run(config.TOKEN)
  • Вопрос задан
  • 1444 просмотра
Решения вопроса 1
Vindicar
@Vindicar
RTFM!
n = print(item['name'])
В-первых, ничего не выводит куда?
Во-вторых, print() выводит данные в стандартный вывод, обычно в консоль. В дискорд через неё ничего не послать.
Во-третьих, print() всегда возвращает None. Так что n всегда будет None, и присваивание не имеет смысла.
В-четвертых, почему не использовать нормальный обработчик команд из discord.ext.commands.Bot? Он тоже позволяет реагировать на сообщения, в придачу к остальным полезностям именно для бота. Это при условии, что ты хочешь именно реакцию на сообщение и не согласен обойтись обычной командой.
В-пятых, если ты не уверен, что такое print(), почему ты пытаешься писать ботов?

Ну про мелочи, вроде "бот парсит игры только при запуске, и не обновляет информацию в дальнейшем" я не говорю...
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

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

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