Skip to content

Frequently Asked Questions

Krypton edited this page Jan 10, 2025 · 3 revisions

Prefix commands are not working?

For prefix commands to work you need to enable the MESSAGE_CONTENT intent on Discord's developer portal. You will also need to enable that intent in the bot's code. You can see here for more information on this regard.

Slash commands are not showing up?

If slash commands are not showing up upon the first start of the bot this is perfectly normal behavior. You will need to synchronize them. You can easily do so by sending the following message in a channel your bot can read messages in

@Bot sync <guild/global>

Of course @Bot is you mentioning your actual bot.

  • If you use sync guild the slash commands will only be available in the current guild where you've executed the command - this is perfect for testing your commands.
  • If you use sync global the slash commands will be available in all guilds across all servers your bot is in - ideally you'd do that once you are sure the commands are working and you want to make them globally available.

Getting a No module named 'audioop' error?

This is because as per Python 3.13, audioop has been removed from the standard library (see https://docs.python.org/3/whatsnew/3.13.html#whatsnew313-pep594).

discord.py officially doesn't support Python 3.13, it is therefore recommended to downgrade your Python installation to 3.12 so that you do not face this issue or eventually other issues later on while coding your bot.

Seeing twice the same slash command?

If you see twice the same slash command for the bot this means that you have both global and guild commands. You will need to unsync them from either the global scope or the guild scope - this can be done with

@Bot unsync <guild/global>

Of course @Bot is you mentioning your actual bot.

The config.json file is not found?

If you are getting an error stating that the config.json file cannot be found, you are most likely running an old version of the template and you should update it.

How to setup the Discord bot template?

You can check the setup page of the wiki.

I'm getting the error "Cannot find module ..."

Firstly make sure you have installed the requirements correctly with

python -m pip install -r requirements.txt

💡 You may need to replace python with py, python3, python3.11, etc. depending on what Python versions you have installed on the machine.

Once that is done, make sure you start the bot with the same command you've installed the requirements with. If you've installed the requirements with python then use python bot.py, if you've installed the requirements with python3 then use python3 bot.py, etc.

What permission(s) should I give to my bot(s)?

Invite your bot only with the permissions it needs to work properly. Do not invite your bot with BAN_MEMBERS permission if your bot will never need that permission.

DO NOT invite any bot with the ADMINISTRATOR (8) permission, it is never needed and no bot requires it.

Why is X not in the Discord bot template?

As the name suggests, it is a template - not a fully fledged Discord bot that anyone would be able to copy paste and publish a bot with it.

The idea behind the template is that newcomers can get their head around what's possible to be done with discord.py. It shows some core concepts such as hybrid commands, select menus, etc. so that you can code your bot yourself. The template is here so that you can get a small reference on what can be done and how it can be done.

💡 If you believe a core functionality of discord.py is missing and not showcased in the template you are free to create an issue or discussion that follows the contributing guidelines.

How to ask a question properly?

The key at getting the most accurate possible answer to your issue is the way you formulate the question and what information you provide.

Some of the most useful information to provide are the following:

  • Share what the full error/traceback is - this will help us getting more context on where the issue is.
  • Give the version of the project that you are using - this will help us isolate the issue.
  • What have you done to get to that error - this will help us replicate the issue.
  • What are the steps you've already tried to fix the issue - this will help us not repeat what you've tried already.

💡 The best is to always try on your own solving the problem with the documentations that are offered, as well as the different search engines.