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

Как объединить две части в коде?

ПЕРВАЯ ЧАСТЬ:
Код
import discord
from discord import utils

import config
intents = discord.Intents.all()


class MyClient(discord.Client):
    async def on_ready(self):
        print('Logged on as {0}!'.format(self.user))

    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 and 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))


# RUN
client = MyClient(intents=intents)
client.run(config.TOKEN)

ВТОРАЯ ЧАСТЬ:
Код.
#hello
@bot.command() # Не передаём аргумент pass_context, так как он был нужен в старых версиях.
async def hello(ctx): 
    author = ctx.message.author 
    await ctx.send(f'Hello, {author.mention}!')



#hello
@bot.command() # Не передаём аргумент pass_context, так как он был нужен в старых версиях.
async def i(ctx): 
    author = ctx.message.author 
    await ctx.send(f'Макс иди нафиг')


#clear
@bot.command()
@commands.has_permissions( administrator = True)

async def clear (ctx, amount = 100):
    await ctx.channel.purge( limit = amount)

#kick
@bot.command()
@commands.has_permissions( administrator = True)

async def kick( ctx, member: discord.Member, *, reason = None ):
    await ctx.channel.purge( limit = 1)

    await member.kick( reason = reason)

#ban
@bot.command()
@commands.has_permissions( administrator = True)

async def ban( ctx, member: discord.Member, *, reason = None ):
    await ctx.channel.purge( limit = 1)

    await member.ban( reason = reason)
    await ctx.send(f"ban user {member.mention}")

#unban
@bot.command()
@commands.has_permissions( administrator = True)

async def unban( ctx, *, member ):
    await ctx.channel.purge( limit = 1)

    banned_users = await ctx.guild.bans()

    for ban_entry in banned_users:
        user = ban_entry.user

        await ctx.guild.unban( user )
        await ctx.send(f"Unbaned user {user.mention}")
        return
  • Вопрос задан
  • 65 просмотров
Подписаться 1 Средний 4 комментария
Пригласить эксперта
Ответы на вопрос 1
в принципе, можно посоздавать cogs, чтобы функции были отдельно, может, удобней)
Ответ написан
Ваш ответ на вопрос

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

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