5
votes

I am writing a small message logging program, I want the bot to only log messages from a specific Guild and for that, I check for the message.guild.id. This, however, raises a problem when there is a message sent in a DM Channel. I want the bot to ignore the Dm channel completely but I did not have much luck in that

The Code:

@commands.Cog.listener()
    async def on_message(self, message):
        if message.guild.id == Guild ID HERE:
            print(f"{message.author} said --- {message.clean_content} --- in #{message.channel.name}")
        elif message.channel.type is discord.ChannelType.private:
            pass
Ignoring exception in on_message
Traceback (most recent call last):
  File "C:\Python38\lib\site-packages\discord\client.py", line 312, in _run_event
    await coro(*args, **kwargs)
  File "d:\Documents\Bots\DS BOT\cog\Listener.py", line 13, in on_message
    if message.guild.id == Guild ID HERE:
AttributeError: 'NoneType' object has no attribute 'id'
Ignoring exception in on_message
Traceback (most recent call last):
  File "C:\Python38\lib\site-packages\discord\client.py", line 312, in _run_event
    await coro(*args, **kwargs)
  File "d:\Documents\Bots\DS BOT\cog\Logger.py", line 12, in on_message
    if message.guild.id == Guild ID HERE:
AttributeError: 'NoneType' object has no attribute 'id'
4
if message.guild is None: returnJoshua Nixon

4 Answers

3
votes

You can just do

if not message.guild:
   # message is from a server
else:
   # message is from a dm.

That's it. There's no need of checking for types.

0
votes

You have to check if the channel is private before doing your guild check otherwise it will raise an error. This should do the job:

@commands.Cog.listener()
    async def on_message(self, message):
        if isinstance(message.channel, discord.DMChannel):
            return
        if message.guild.id == Guild ID HERE:
            print(f"{message.author} said --- {message.clean_content} --- in #
0
votes

The way I solved this was simple. At the time I set up a custom prefix system that would give every server the bot is in its own default prefix which could be later changed. The thing with Dm's is that it's not a server and therefore was not in the prefix database causing the error.

This was solved with:

def get_prefix(bot, message):
    if (message.guild is None):
        return '.'
    else:
        with open('prefixes.json', 'r') as f:
            prefixes = json.load(f)
        return prefixes[str(message.guild.id)]

Simply if the message or command that was received was not sent from a server, it would simply use the default prefix

-1
votes

Pass this inside your if statement:

if message.channel.type is discord.ChannelType.private: 
    return

This should work for you!