Задать вопрос
  • Как вписать в дискорд бота команду по выдаче роли с удалением предыдущих ролей?

    Zagir-vip
    @Zagir-vip
    Web dev, Game dev, app dev, Разработчик на Python!
    Специально для Вас и для опыта писал данный код:

    import discord
    import json
    import asyncio
    
    from discord.ext import commands
    
    @client.event
    async def on_ready():
    	with open("test.json", 'r') as f:
    		data = json.load(f)
    		for i in range(len(data)):
    			member = await (await client.fetch_guild(data[i]["guild_id"])).fetch_member(data[i]["id"])
    			client.loop.create_task(pun_start(member))
    	print("ready")
    
    def check_user_db(user_id:int):
    	with open('test.json', 'r') as f:
    		data = json.load(f)
    		for i in range(len(data)):
    			if data[i]["id"] == user_id: return True
    	return False
    
    def add_user_db(user_id:int, guild_id:int, author:str, timeout:int, reason:str, roles:list, role_pun:int):
    	if check_user_db(user_id) is True: return False
    	else:
    		with open('test.json', 'r') as f:
    			data = json.load(f)
    
    		new_user = {
    		"id": user_id,
    		"guild_id": guild_id,
    		"author": f"{author.name}#{author.discriminator}",
    		"timeout": timeout,
    		"reason": reason,
    		"roles": roles,
    		"role_pun": role_pun
    		}
    		data.append(new_user)
    
    		with open('test.json', 'w') as f:
    			json.dump(data, f, indent=3)
    
    		return True
    
    def remove_user_db(user_id:int):
    	if check_user_db(user_id) is False: return False
    	else:
    		with open('test.json', 'r') as f:
    			data = json.load(f)
    			for i in range(len(data)):
    				if data[i]["id"] == user_id:
    					del data[i]
    					with open('test.json', 'w') as f:
    						json.dump(data, f)
    					return True
    		return False
    
    async def pun_start(user):
    	with open('test.json', 'r') as f:
    		data = json.load(f)
    		user_data = {}
    		for i in range(len(data)):
    			if data[i]["id"] == user.id: user_data = data[i]; break
    		role_pun = discord.utils.get(user.guild.roles, id=id_роли) # роль для наказания
    		old_roles = user_data["roles"] # старые роли участника
    		await asyncio.sleep(user_data["timeout"])
    		await user.remove_roles(role_pun)
    		for role in old_roles:
    			role_user = discord.utils.get(user.guild.roles, id=role)
    			await user.add_roles(role_user)
    		remove_user_db(user.id)
    
    
    
    @client.command()
    async def pun(ctx, member:discord.Member=None, timeout:int=None, reason:str="Не указано"):
    	if member is None or timeout is None:
    		await ctx.reply("Укажите участника и время.\nПример: !pun @участник 100 - наказываем участника на 100сек.\n**Важно:** Время указывается в секундах!")
    	elif check_user_db(member.id) is True:
    		await ctx.reply("Участника уже наказан!")
    	else:
    		role_pun = discord.utils.get(ctx.guild.roles, id=id_роли) # роль для наказания
    		old_roles = [] # старые роли участника
    		for role in member.roles:
    			if role.name != "@everyone":
    				old_roles.append(role.id)
    				await member.remove_roles(role)
    		await member.add_roles(role_pun)
    		add_user_db(member.id, ctx.guild.id, ctx.author, timeout, reason, list(old_roles), role_pun.id) # добавляем участника в файл
    		await ctx.send(f"{member.mention}, наказан!\nПричина: {reason}")
    		await asyncio.sleep(timeout)
    		await member.remove_roles(role_pun)
    		for role in old_roles:
    			role_user = discord.utils.get(ctx.guild.roles, id=role)
    			await member.add_roles(role_user)
    		remove_user_db(member.id)
    		await ctx.send(f"Наказания с {member.mention} снято!\nПричина: Автоматическое снятие")


    Если будут ошибки пишите Xpeawey#5262
    Ответ написан
  • А возможно ли в телеграм боте реализовать такой функционал?

    Zagir-vip
    @Zagir-vip
    Web dev, Game dev, app dev, Разработчик на Python!
    Если уже не поздно то вот пример:
    user_phone = "8 928 000 00 00" # Данные пользователя
    user_email = "example@example.com" # Данные пользователя
    
    allowed = ["gmail.com", "mail.ru", "yandex.ru"] # Разрещённые почты
    
    # форматируем номер телефона
    user_phone = user_phone.replace(" ", "") # Уберём пробелы
    
    if len(user_phone) != 11:
    	# Длинна номера не равна 11 символам
    	pass
    elif user_email.split("@")[1] not in allowed:
    	# Почта не верно указана
    	pass
    else:
    	# Всё хорошо
    	pass
    Ответ написан
    Комментировать
  • Как заставить discord бота считывать данные с отправленного сообщения?

    Zagir-vip
    @Zagir-vip
    Web dev, Game dev, app dev, Разработчик на Python!
    @client.event
    async def on_message(message):
    	def check(m):
    		return m.author == ctx.author and m.channel == ctx.channel # Принимаем данные только пользователя который написал 'Func'
    	if message.author == client.user:
    		return
    	if message.channel.startswith("Func")
    		await message.channel.send("Введите имя")
    		data1 = await client.wait_for('message', check=check, timeout=60) # timeout=60 - в течении 60 сек. мы будем принимать сообщения
    		await message.channel.send("Введите пароль")                      # ВАЖНО: Мы принимаем ОДНО сообщение.
    		data2 = await client.wait_for('message', check=check, timeout=60)
    
    		# или бесконечно принимать данные
    		await message.channel.send("Введите данные")
    		while True:
    			data = await client.wait_for('message', check=check) # Так мы будем бесконечно принимать сообщения.
    Ответ написан
    Комментировать
  • Как сделать что бы команда работало только в лс aiogram?

    Zagir-vip
    @Zagir-vip
    Web dev, Game dev, app dev, Разработчик на Python!
    @dp.message_handler(content_types=['photo'])
    async def cmd(message):
        if message.chat.type == "private":
            # действие
       else:
          await message.reply("Пользуйтесь ботом в личных сообщениях!")
    Ответ написан
    5 комментариев
  • Почему левый ползунок выходит за границы?

    Zagir-vip
    @Zagir-vip
    Web dev, Game dev, app dev, Разработчик на Python!
    попробуйте обернуть данный код в div и задать width: размер;.
    Ответ написан
    Комментировать
  • Есть ли в discord.py функция, отвечающая за жалобу на пользователя/сервер?

    Zagir-vip
    @Zagir-vip
    Web dev, Game dev, app dev, Разработчик на Python!
    здравствуйте, такой функции нету, как но её можно написать.

    вот код
    @client.command(aliases = ['репорт']) #aliases это список название для команды
    async def report(ctx, *, message):
    channel = discord.uttils.get(ctx.guild.TextChannels, name = 'название канала') 
    await channel.send(f'новая жалоба\n{message} ') 
    await ctx.send('жалоба отправлена', delete_after = 5)
    
    вот пример кода. Улучшите его с помощью embed. 
    поправьте табуляцию, так как с телефона писать не легко.
    Ответ написан
  • Как работать с когами discord.py discord_components?

    Zagir-vip
    @Zagir-vip
    Web dev, Game dev, app dev, Разработчик на Python!
    Здраствуйте вы не правильно отправляете embed с components

    Вот правильно:

    emb = discord.Embed(title='Ивенты', description=f'Выберите ивент который хотите провести.', 
      components=[
                    Button(style=ButtonStyle.gray, label='CodeNames', emoji=''),
                    Button(style=ButtonStyle.gray, label='Бункер', emoji=''),
                    Button(style=ButtonStyle.gray, label='Дурак Онлайн', emoji=''),
                    Button(style=ButtonStyle.gray, label='Шляпа', emoji=''),
                    Button(style=ButtonStyle.gray, label='Сломанный телефон', emoji='')
                ])
            emb.set_thumbnail(url=ctx.author.avatar_url)
            msg = await ctx.send(embed = emb)
    Ответ написан
  • Dislash.py вылазит ошибка, что делать?

    Zagir-vip
    @Zagir-vip
    Web dev, Game dev, app dev, Разработчик на Python!
    вот код:

    async def play(ctx, inter):
     inter.send('текст')
    Ответ написан
  • Ошибка в кода бота дискорда. Как сделать нормально?

    Zagir-vip
    @Zagir-vip
    Web dev, Game dev, app dev, Разработчик на Python!
    Команда help уже есть вот код замените его на ваш:

    client = commands.Bot( command_prefix = PREFIX )
    client.remove_command('help')

    вот команда help лучше:

    @client.command( pass_context = True )
    
    async def help( ctx ):
        ebm = discord.Embed( title = 'Все наши команды' )
    
        emb.add_field( name = f'{ PREFIX }help',  value = 'Помощь по командам' )
        emb.add_field( name = f'{ PREFIX }helpme', value = 'Помощь по командам в личку' )
        emb.add_field( name = f'{ PREFIX }clear', value = 'очистка чата (только для админов)' )
        emb.add_field( name = f'{ PREFIX }kick', value = 'кикнуть юзера (только для админов)' )
        emb.add_field( name = f'{ PREFIX }ban', value = 'забанить юзера (только для админов)' )
    
        await ctx.send( embed = emb )


    напишите мне в дискорд я вам много чего покажу: Xpeawey#6098
    Ответ написан
    Комментировать
  • Где запускать код?

    Zagir-vip
    @Zagir-vip
    Web dev, Game dev, app dev, Разработчик на Python!
    Здраствуйте, вы можете купить хостинг

    Бесплатные хостинги:
    1.Heroku
    2.GitHub
    Ответ написан
    Комментировать
  • Как сделать tempmute или мут на некоторое время?

    Zagir-vip
    @Zagir-vip
    Web dev, Game dev, app dev, Разработчик на Python!
    Вот вам большой, но сам лучший код на мут со временем как в Mee6

    https://pastebin.com/Q7NNj46e #Просто слишком много слов!
    Ответ написан
    1 комментарий
  • Как сделать рассылку в телеграм боте?

    Zagir-vip
    @Zagir-vip
    Web dev, Game dev, app dev, Разработчик на Python!
    В команде:
    @bot.message_handler(commands=['special'])
    def mess(message):
      for user in joinedUsers:
        bot.send_message(user, message.text[message.text.find(' '):])
    
    Вы открыли файл joinedUsers и закрыли попробуйте этот код:
    
    @bot.message_handler(commands=['special'])
    def mess(message):
      joinedFile = open("joined.txt", "r")
      joinedUsers = set ()
      for user in joinedUsers:
        bot.send_message(user, message.text[message.text.find(' '):])


    если не работает скиньте пожалуйста ошибку или свяжитесь со мной в дискорде: Xpeawey#6098
    Ответ написан
  • Как сделать, чтобы бот, принимал сообщение от пользователя и отправлял от своего имени?

    Zagir-vip
    @Zagir-vip
    Web dev, Game dev, app dev, Разработчик на Python!
    Бот принимает команду say!
    Использование: [префикс]say [сообщение]

    КОД:
    @client.command()
    @commands.has_permissions(view_audit_log = True) #права команды: Просматривать аудит логи
    async def say(ctx, *, arg = None):
        emb = discord.Embed(description = f'{arg}', color = 0x0944d9) #цвет синий
    
        await ctx.send(embed = emb) #отправка сообщения
    
    @say.error #если у участника нету прав просматривать аудит лог то пишем ему то что у вас не достаточно прав!
    async def say_error(ctx, error):
        if isinstance(error, commands.MissingPermissions):
            emb = discord.Embed(titile = f'Ошибка', description = f'**У вас недостаточно прав!**', color = RED)
            emb.set_footer(text = f'{client.user.name} © 2020 | Все права защищены', icon_url = client.user.avatar_url)
            await ctx.send(embed = emb, delete_after = 15)
    Ответ написан