Following Python’s Development#

Python’s development is communicated through a myriad of ways, primarily Discourse along with other platforms.

Standards of behaviour in these communication channels#

We try to foster environments of mutual respect, tolerance and encouragement, as described in the PSF’s Diversity Statement. Abiding by the guidelines in this document and asking questions or posting suggestions in the appropriate channels are an excellent way to get started on the mutual respect part, greatly increasing the chances of receiving tolerance and encouragement in return.

Mailing Lists#


Some mailing lists have been supplanted by categories in the Python Discourse. Specifically,

  • The python-dev list is superseded by the Core Development and PEPs categories on Discourse.

  • The python-ideas list is superseded by posts in the Ideas category on Discourse.

Discussion in Core Development is focused on issues related to Python’s own development, such as how to handle a specific issue, a PEP, etc.

  • Ideas about new functionality should not start here, and instead should be discussed in Ideas.

  • Technical support questions should also not be asked here, and instead should go to the python-list or python-help mailing lists, or the Python Help category on Discourse.

Existing threads on the python-dev, python-committers, and python-ideas mailing lists can be accessed through the online archive.

General Python questions should go to python-list or tutor or similar resources, such as StackOverflow or the #python IRC channel on Libera.Chat.

The core-workflow issue tracker is the place to discuss and work on improvements to the CPython core development workflow.

A complete list of Python mailing lists can be found at (older lists, using Mailman2) or (newer lists, using Mailman3). Some lists may also be mirrored at GMANE and can be read and posted to in various ways, including via web browsers, NNTP newsreaders, and RSS feed readers.

Discourse ( web forum)#

We have our own Discourse forum for both developers and users. This forum complements the python-dev, python-ideas, python-help, and python-list mailing lists.

This forum has different categories and most core development discussions take place in the open forum categories for PEPs and Core Development (these are the Discourse equivalents to the python-dev mailing list). All categories are open for users to read and post with the exception of the Committers category, where posting is restricted to the CPython core developers.

The Committers category is often used for announcements and notifications. It is also the designated venue for the core developer promotion votes (as the Discourse equivalent of the python-committers mailing list).

Tutorials for new users#

To start a topic or participate in any discussions in the forum, sign up and create an account using an email address or GitHub account. You can do so by clicking the “Sign Up” button on the top right hand corner of the Discourse main page.

The Python Discourse Quick Start compiled by Carol Willing gives you a quick overview on how to kick off Python Discourse.

We recommend new users getting familiarised with the forum by going through Discobot tutorials. These tutorials can be activated by replying to a welcome message from “discourse Greetings!” received under Notifications and Messages in your user account.

  • Click on your personal account found on the top right hand corner of the page.

  • The dropdown menu will show four different icons: 🔔 (Notifications), 🔖 (Bookmarks), ✉️ (Messages), and 👤 (Preferences).

  • Select either Notifications or Messages.

  • Open the “Greetings!” message sent by Discobot to start the tutorial.

Ensure that you read through the Python Code of Conduct. We are to be open, considerate and respectful to all users in the community. You can report messages that don’t respect the CoC by clicking on the three dots under the message and then on the ⚐ icon. You can also mention the @staff, @moderators, or @admins groups in a message.

Reading topics#

Click a topic title and read down the list of replies in chronological order, following links or previewing replies and quotes as you go. Use your mouse to scroll the screen, or use the timeline scroll bar on the right which also shows you how far through the conversation you’ve read. On smaller screens, select the bottom progress bar to expand it.


Following categories (Category notifications)#

Notifications can be set for individual categories and topics. To change any of these defaults, you can either go to your user preferences, or visit the category page, and use the notification button 🔔 above the topic list, on the top right hand corner of the category page beside the “+ New Topic” button.

Clicking on the Notification control 🔔 will show a drop-down panel with 5 different options: Watching, Tracking, Watching First Post, Normal, and Muted. All categories are set by default in Normal mode where you will only be notified if someone mentions your @name or replies to you.

Following individual threads (Topic notifications)#

To follow any individual topics or threads, you can adjust your notifications through the notification button 🔔 found on the right of the topic at the end of the timeline. You can also do so at the bottom of each topic. Select “Watching” and you will be notified when there is any new updated reply from that particular thread.

Customising notifications on user preference#

To get a bird’s eye view of all your customised notifications, you can go to Preferences of your account. This allows you to make adjustments according to categories, users, and tags.

Enabling mailing list mode#

In mailing list mode, you will receive one email per post, as happens with traditional mailing lists. This is desirable if you prefer to interact via email, without visiting the forum website. To activate the mailing list mode, go to the email preferences, check “Enable mailing list mode” and save changes.

Discord (private chat server)#

For more real-time discussions, the core development team have a private Discord server available. Core developers, Steering Council members, triagers, and documentarians on the project are eligible to join the server. Joining the Discord server is entirely optional, as all essential communications occur on the mailing lists and Discourse forums.

For core developers, a long lived multiple use invitation link for this server can be found in the private core developer only section of the Discourse forum.

For triagers and documentarians joining the Discord server, a single use invitation link should be generated and sent to them directly.

When first joining the server, new users will only have access to the #welcome and #rules-and-info channels. To link their Discord ID with their project role, core developers may update their Steering Council 🔒 voter record with their Discord ID before posting in the #welcome channel to request access to the rest of the server channels. Triagers, documentarians, and core developers that would prefer not to add their Discord ID to their Steering Council voter record may instead be vouched for by an existing member of the Discord server.

As a private, non-archived, forum, final decisions on design and development questions should not be made on Discord. Any conclusions from Discord discussions should be summarised and posted to the issue tracker, Discourse forum, or mailing list (the appropriate venue for sharing conclusions will depend on the specific discussion).

Note: existing Discord users may want to right click on their username in the automatic Discord welcome message and choose “Edit Server Profile” in order to set a specific Server Nickname


Some core developers still participate in the #python-dev IRC channel on This is not a place to ask for help with Python, but to discuss issues related to Python’s own development. See also the #python-dev-notifs channel for bots notifications.


Several core developers are active bloggers and discuss Python’s development that way. You can find their blogs (and various other developers who use Python) at

Setting Expectations for Open Source Participation#

Burn-out is common in open source due to a misunderstanding of what users, contributors, and maintainers should expect from each other. Brett Cannon gave a talk about this topic that sets out to help everyone set reasonable expectations of each other in order to make open source pleasant for everyone involved.

Additional Repositories#

Python Core Workflow hosts the codebase for tools such as cherry_picker and blurb.

Python Performance Benchmark project is intended to be an authoritative source of benchmarks for all Python implementations.