Skip to main content

A simple command line podcast feed syncer

Project description

podpuller

A simple python app to sync your podcasts with RSS feeds and transfer to an external MP3 player

PyPI version License: MIT

Quick Start

  1. pip install podpuller
  2. Copy feeds.example.conf to ~/.config/podpuller/feeds.conf
  3. Put in URLs of RSS feeds, using a unique section name for each feed. No need to put in title.
  4. You can now use the command podpuller

podpuller screenshot

Motivation

After giving up my smartphone and buying a cheapo MP3 player I wanted a way to keep my feeds synced.

There are many great programs for this out there, like Greg, but it didn't really fit my workflow, which was having a certain number of the newest episodes of each podcast, and manually marking the ones I have already listened to.

This is that app. It was heavily inspired (and liberally copied) from the excellent upodder which is no longer maintained.

Workflow

Config: ~/.config/podpuller/feeds.conf

  1. Choose your RSS feeds
  2. Specify how many episodes you want (can be 'all')
  3. Choose serial (oldest first) or regular + optional start date

Run: podpuller [opt:single_feed]

  1. Mark the ones you listened to (or skip with "quick mode")
  2. Wait for sync (only syncs single feed if specified)
  3. Optionally, transfer to external drive

Config

The config file is read from ~/.config/podpuller/feeds.conf and you have an example here. It is pretty straightforward:

Global Configs
  • data directory: Where to store the SQL database of downloaded and listened episodes.
  • download directory: Where to download the podcasts to.
  • mp3 player directory: Where to sync the download directory to.
Feed Configs
  • Every feed goes into a directory named by its config file section (e.g., tal in the sample conf file).
  • The serial config gets episodes from oldest to newest.
  • start date ignores everything before that date (useful for serial podcasts).
  • There's no need to provide a name for the feed, just a URL, the name will be auto-filled from the RSS feed.

Notes

  • Sync both transfers and deletes files. It basically does an exact copy.
  • All defaults, including rsync flags, are for MacOS but can probably be easily changed for UN*X systems.

Rant

RSS is a long-standing open standard for updated feeds. Your podcast success is built on the shoulders of many open-source and open-format developers who poured their heart into it. Please stop making your podcast available only through proprietary channels like Spotify, iTunes, etc. Give back by also publishing your RSS feed. Thanks!

Roadmap

  • Tag MP3 files with info from feed
  • Put project on PyPI
  • UI improvements
  • Handle "oldest-first" workflow for serial podcasts

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

podpuller-1.4.6.tar.gz (10.7 kB view details)

Uploaded Source

Built Distribution

podpuller-1.4.6-py3-none-any.whl (10.7 kB view details)

Uploaded Python 3

File details

Details for the file podpuller-1.4.6.tar.gz.

File metadata

  • Download URL: podpuller-1.4.6.tar.gz
  • Upload date:
  • Size: 10.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.4

File hashes

Hashes for podpuller-1.4.6.tar.gz
Algorithm Hash digest
SHA256 d70ccd8e37010c37792d12c186fbb61c1c71cef93c9a9a5c306ff75a2bfed71b
MD5 89ed8458653326bd810e04a9c9d6915c
BLAKE2b-256 35b1f7ec57e16d4164d7d6825648825438edd08c0ad7cf955624d084ecf32753

See more details on using hashes here.

File details

Details for the file podpuller-1.4.6-py3-none-any.whl.

File metadata

  • Download URL: podpuller-1.4.6-py3-none-any.whl
  • Upload date:
  • Size: 10.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.4

File hashes

Hashes for podpuller-1.4.6-py3-none-any.whl
Algorithm Hash digest
SHA256 5748c6e1f2de32c18277e71984f0a3dd7f12cff40b3c42c9b0ba92eafca63ddc
MD5 077b0f81b262c2fc1e52f2d12985eec2
BLAKE2b-256 97728028551475466ffe78c20812b93ef14120021c178fc6dfda0da509f5bcae

See more details on using hashes here.

Supported by

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