Skip to main content

A Python wrapper for the Discord API

Project description

Discord server invite PyPI version info PyPI supported Python versions PyPI downloads

A fork of discord.py. Pycord is a modern, easy to use, feature-rich, and async ready API wrapper for Discord written in Python.

What Happened to Discord.py?

Rapptz, also known as Danny, the maintainer and core developer of discord.py will no longer be updating it. Here’s his Full explanation and an FAQ.

Pycord v1.7.3 is the same as discord.py v1.7.3, however, Pycord v2.0 will support newer features of the API such as slash commands, context menus, scheduled events, timeouts, and others.

Key Features

  • Modern Pythonic API using async and await.

  • Proper rate limit handling.

  • Optimised for both speed and memory usage.

  • Full Application Command Support

Installing

Python 3.8 or higher is required

To install the library without full voice support, you can just run the following command:

# Linux/macOS
python3 -m pip install -U py-cord

# Windows
py -3 -m pip install -U py-cord

Otherwise to get voice support you should run the following command:

# Linux/macOS
python3 -m pip install -U "py-cord[voice]"

# Windows
py -3 -m pip install -U py-cord[voice]

To install additional packages for speedup, run the following command:

# Linux/macOS
python3 -m pip install -U "py-cord[speed]"
# Windows
py -3 -m pip install -U py-cord[speed]

To install the development version, do the following:

$ git clone https://github.com/Pycord-Development/pycord
$ cd pycord
$ python3 -m pip install -U .[voice]

Optional Packages

Please note that while installing voice support on Linux, you must install the following packages via your preferred package manager (e.g. apt, dnf, etc) BEFORE running the above commands:

  • libffi-dev (or libffi-devel on some systems)

  • python-dev (e.g. python3.10-dev for Python 3.10)

Quick Example

import discord

bot = discord.Bot()

@bot.slash_command()
async def hello(ctx, name: str = None):
    name = name or ctx.author.name
    await ctx.respond(f"Hello {name}!")

@bot.user_command(name="Say Hello")
async def hi(ctx, user):
    await ctx.respond(f"{ctx.author.mention} says hello to {user.name}!")

bot.run("token")

Traditional Commands Example

import discord
from discord.ext import commands

bot = commands.Bot(command_prefix=">")

@bot.command()
async def ping(ctx):
    await ctx.send("pong")

bot.run("token")

You can find more examples in the examples directory.

Note: Make sure you do not reveal your bot token to anyone, it can grant access to your bot.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

discord2-2.0.1.tar.gz (882.0 kB view details)

Uploaded Source

Built Distribution

discord2-2.0.1-py3-none-any.whl (995.1 kB view details)

Uploaded Python 3

File details

Details for the file discord2-2.0.1.tar.gz.

File metadata

  • Download URL: discord2-2.0.1.tar.gz
  • Upload date:
  • Size: 882.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/32.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.61.2 importlib-metadata/4.2.0 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.1

File hashes

Hashes for discord2-2.0.1.tar.gz
Algorithm Hash digest
SHA256 9e01f061784cfd47dc9b8a9d8edc889a9ccc99e31ea8af929d15a7e3928e60b6
MD5 fdf0612d30d22419197bd1304ea35020
BLAKE2b-256 333ddd856badda0fe18c58336d6624c056dfee257b6af099405e9e6271c12ee1

See more details on using hashes here.

File details

Details for the file discord2-2.0.1-py3-none-any.whl.

File metadata

  • Download URL: discord2-2.0.1-py3-none-any.whl
  • Upload date:
  • Size: 995.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/32.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.61.2 importlib-metadata/4.2.0 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.1

File hashes

Hashes for discord2-2.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 f94744da9ff84add6994a75d0c300c84237110df1e0a3361b7adb7cb29e41e04
MD5 36e35bec3e5359c7aed46f87d0ed4834
BLAKE2b-256 7a5cb34c8ee41fc42596ef978bacebae60e7e5edf6f03e9db83c7f06f642610e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page