The Real Python Podcast

Going Beyond requirements.txt With pylock.toml and PEP 751


Listen Later

What is the best way to record the Python dependencies for the reproducibility of your projects? What advantages will lock files provide for those projects? This week on the show, we welcome back Python Core Developer Brett Cannon to discuss his journey to bring PEP 751 and the pylock.toml file format to the community.

Brett has been working on a way to move beyond the requirements.txt file for over six years. He was on the show previously to discuss his work on PEP 665, which was rejected. He decided to continue to push forward, authoring PEP 751 last year, which was accepted at the end of March this year.

The PEP calls for a new file format to record your project’s dependencies. The goal was to have a standardized immutable record for what should be installed to reproduce your project in a virtual environment. He discusses working with other packaging projects and the compromises involved in creating a standard.

Course Spotlight: Using the Python subprocess Module

In this video course, you’ll learn how to use Python’s subprocess module to run and control external programs from your scripts. You’ll start with launching basic processes and progress to interacting with them as they execute.

Topics:

  • 00:00:00 – Introduction
  • 00:02:38 – Brett’s roles within the Python community
  • 00:05:41 – How to move beyond requirement.txt?
  • 00:10:58 – What does the community use as project artifacts?
  • 00:15:28 – Building on the success of pyproject.toml
  • 00:17:44 – Introducing PEP 665
  • 00:19:49 – Software Bills of Materials and security
  • 00:25:20 – Back to lock files and security
  • 00:31:08 – Video Course Spotlight
  • 00:32:27 – Not giving up on the idea
  • 00:34:01 – Leading into PEP 751
  • 00:38:54 – Working toward a single multi-platform file
  • 00:43:02 – The final push
  • 00:48:54 – Leaving room for flexibility
  • 00:53:50 – And it’s done, PEP 751 accepted unconditionally
  • 00:58:06 – Keynote speaker at EuroPython 2025
  • 00:58:45 – What are uv workspaces?
  • 01:01:02 – Considering the use of lock files in data science
  • 01:05:23 – Updates about Python for WASI and Emscripten
  • 01:13:51 – Clarification on WASI
  • 01:20:28 – Future conversation about Python launcher
  • 01:23:04 – What are you excited about in the world of Python?
  • 01:24:25 – What do you want to learn next?
  • 01:28:41 – What’s the best way to follow your work online?
  • 01:31:00 – Thanks and goodbye
  • Show Links:

    • Tall, Snarky Canadian
    • BREAKING: Guido van Rossum Returns as Python’s BDFL - YouTube
    • Python Packaging User Guide
    • PEP 751 – A file format to record Python dependencies for installation reproducibility
    • PEP 665 – A file format to list Python dependencies for reproducibility of an application
    • pylock.toml Specification - Python Packaging User Guide
    • Inline script metadata - Python Packaging User Guide
    • PEP 723 – Inline script metadata
    • Using workspaces - uv
    • Do you have a flag? - Eddie Izzard - YouTube
    • OpenBLAS : An optimized BLAS library
    • EuroPython 2025 - July 14 to 20, 2025 - Prague, Czech Republic & Remote
    • Bytecode Alliance
    • Recent conversations - Bytecode Alliance - Zulip
    • My impressions of Gleam
    • My impressions of ReScript
    • Python on Exercism
    • Brett Cannon’s Films - Letterboxd
    • Media I Like - Open Source by Brett Cannon
    • Brett Cannon (@snarky.ca) — Bluesky
    • Brett Cannon (@[email protected]) - Fosstodon
    • Level up your Python skills with our expert-led courses:

      • Python Basics Exercises: Installing Packages With pip
      • Everyday Project Packaging With pyproject.toml
      • Using the Python subprocess Module
      • Support the podcast & join our community of Pythonistas

        ...more
        View all episodesView all episodes
        Download on the App Store

        The Real Python PodcastBy Real Python

        • 4.7
        • 4.7
        • 4.7
        • 4.7
        • 4.7

        4.7

        138 ratings


        More shows like The Real Python Podcast

        View all
        Software Engineering Radio by se-radio@computer.org

        Software Engineering Radio

        273 Listeners

        The Changelog: Software Development, Open Source by Changelog Media

        The Changelog: Software Development, Open Source

        292 Listeners

        Software Engineering Daily by Software Engineering Daily

        Software Engineering Daily

        623 Listeners

        Talk Python To Me by Michael Kennedy

        Talk Python To Me

        585 Listeners

        Thoughtworks Technology Podcast by Thoughtworks

        Thoughtworks Technology Podcast

        42 Listeners

        Super Data Science: ML & AI Podcast with Jon Krohn by Jon Krohn

        Super Data Science: ML & AI Podcast with Jon Krohn

        303 Listeners

        Python Bytes by Michael Kennedy and Brian Okken

        Python Bytes

        214 Listeners

        Data Engineering Podcast by Tobias Macey

        Data Engineering Podcast

        145 Listeners

        Syntax - Tasty Web Development Treats by Wes Bos & Scott Tolinski - Full Stack JavaScript Web Developers

        Syntax - Tasty Web Development Treats

        983 Listeners

        CoRecursive: Coding Stories by Adam Gordon Bell - Software Developer

        CoRecursive: Coding Stories

        189 Listeners

        DataFramed by DataCamp

        DataFramed

        268 Listeners

        Kubernetes Podcast from Google by Abdel Sghiouar, Kaslin Fields

        Kubernetes Podcast from Google

        182 Listeners

        Practical AI by Practical AI LLC

        Practical AI

        213 Listeners

        AWS Podcast by Amazon Web Services

        AWS Podcast

        201 Listeners

        The Stack Overflow Podcast by The Stack Overflow Podcast

        The Stack Overflow Podcast

        62 Listeners