Итак, у меня есть две таблицы: «Серверы» и «Забастовки». В таблице «Серверы» указано максимальное количество страйков. Я хочу сравнить количество страйков, которые имеет пользователь, с максимальным количеством забастовок, указанным в таблице «Серверы». Я пробовал это:

@commands.command(name='strike', pass_ctx= True)
@commands.has_permissions(manage_messages=True)

async def strike(self, ctx, member : discord.Member):
    
    first_strike = 1
    
    
    cursor = await self.client.db.cursor()
    await cursor.execute(f"SELECT Strikes_Have FROM Strikes WHERE Guild_ID = {ctx.guild.id} AND User_ID = {member.id}")
    result = await cursor.fetchone()
    
    if result == None:
        
        cursor = await self.client.db.cursor()
            
        sql = f"INSERT INTO Strikes(Guild_ID, User_ID, Strikes_Have) VALUES({ctx.guild.id}, {member.id}, {first_strike})"
            
    
    else:
        
        cursor = await self.client.db.cursor()
            
        sql = f"UPDATE Strikes SET Strikes_Have = Strikes_Have + 1 where Guild_ID = {ctx.guild.id} AND User_ID = {member.id}"
        
        if result["Strikes_Have"] == result["MAX_STRIKES"]:
            await ctx.message.channel.send(f"{member} has the max amount of stirkes specified by the server")
            
            
    await cursor.execute(sql)
    await self.client.db.commit()
    await cursor.close()
            
    await ctx.message.channel.send(f"Striked {member}")`

Но получил эту ошибку:

Traceback (most recent call last):
  File "/home/pi/.local/lib/python3.7/site-packages/discord/ext/commands/core.py", line 85, in wrapped
    ret = await coro(*args, **kwargs)
  File "/home/pi/EndorCore/cogs/Mod.py", line 225, in strike
    if result["Strikes_Have"] == result["MAX_STRIKES"]:
IndexError: No item with that key
1
StandingPad Animations 2 Май 2021 в 23:31

1 ответ

Лучший ответ

Сообщение об ошибке, которое вы получаете в настоящее время, вызвано тем, что вы пытаетесь получить доступ к столбцу данных, которого нет в таблице предупреждений. Чтобы получить максимальное значение страйков, вам нужно запросить эту таблицу и получить число, а затем сравнить два. Например:

cursor.execute(f"SELECT Strikes_Have FROM Strikes WHERE Guild_ID = {ctx.guild.id} AND User_ID = {member.id}")
user_result = cursor.fetchone()

cursor.execute(f"SELECT MAX_STRIKES FROM Servers WHERE Guild_ID = {ctx.guild.id}")
server_result = cursor.fetchone()

if user_result["Strikes_Have"] == server_result['MAX_STRIKES']:
    print("User has max strikes")
1
Kelo 2 Май 2021 в 22:50