Skip to main content

A python wrapper for the Podcast Index API (podcastindex.org).

Project description

python-podcastindex

A python wrapper for the Podcast Index API (podcastindex.org)

Installation

pip install python-podcastindex

Usage

  1. Init the podcast index
  2. Search
  3. Podcasts
  4. Episodes of a podcast
  5. Episode by ID
  6. Recent episodes

Init the podcast index

import podcastindex

config = {
    "api_key": "YOUR API KEY HERE",
    "api_secret": "YOUR API SECRET HERE"
}

index = podcastindex.init(config)

Search

result = index.search("This American Life")
result = index.search("This American Life", clean=True)
Click to see sample result!
  {
      "status": "true",
      "feeds": [
          {
              "id": 522613,
              "title": "This American Life",
              "url": "http://feed.thisamericanlife.org/talpodcast",
              "originalUrl": "http://feed.thisamericanlife.org/talpodcast",
              "link": "https://www.thisamericanlife.org",
              "description": "This American Life is a weekly public ...",
              "author": "This American Life",
              "ownerName": "",
              "image": "https://files.thisamericanlife.org/sites/all/themes/thislife/img/tal-name-1400x1400.png",
              "artwork": "https://files.thisamericanlife.org/sites/all/themes/thislife/img/tal-name-1400x1400.png",
              "lastUpdateTime": 1607323495,
              "lastCrawlTime": 1607632436,
              "lastParseTime": 1607323495,
              "lastGoodHttpStatusTime": 1607632436,
              "lastHttpStatus": 200,
              "contentType": "text/xml; charset=UTF-8",
              "itunesId": 201671138,
              "generator": null,
              "language": "en",
              "type": 0,
              "dead": 0,
              "crawlErrors": 0,
              "parseErrors": 0,
              "categories": {
                  "77": "Society",
                  "78": "Culture",
                  "1": "Arts",
                  "55": "News",
                  "59": "Politics"
              },
              "locked": 0,
              "imageUrlHash": 1124696616
          },
          ...
      ],
      "count": 8,
      "query": "This American Life",
      "description": "Found matching feeds."
  }

Podcasts

results = index.podcastByFeedId(522613)
results = index.podcastByFeedUrl("http://feed.thisamericanlife.org/talpodcast")
results = index.podcastByItunesId(201671138)
Click to see sample result!
  {
      "status": "true",
      "query": {
          "id": "201671138"
      },
      "feed": {
          "id": 522613,
          "title": "This American Life",
          "url": "http://feed.thisamericanlife.org/talpodcast",
          "originalUrl": "http://feed.thisamericanlife.org/talpodcast",
          "link": "https://www.thisamericanlife.org",
          "description": "This American Life is a weekly public radio show, heard by 2.2 million people on more than 500 stations. Another 2.5 million people download the weekly podcast. It is hosted by Ira Glass, produced in collaboration with Chicago Public Media, delivered to stations by PRX The Public Radio Exchange, and has won all of the major broadcasting awards.",
          "author": "This American Life",
          "ownerName": "",
          "image": "https://files.thisamericanlife.org/sites/all/themes/thislife/img/tal-name-1400x1400.png",
          "artwork": "https://files.thisamericanlife.org/sites/all/themes/thislife/img/tal-name-1400x1400.png",
          "lastUpdateTime": 1607927945,
          "lastCrawlTime": 1608430718,
          "lastParseTime": 1608376393,
          "lastGoodHttpStatusTime": 1608430718,
          "lastHttpStatus": 200,
          "contentType": "text/xml; charset=UTF-8",
          "itunesId": 201671138,
          "generator": null,
          "language": "en",
          "type": 0,
          "dead": 0,
          "crawlErrors": 0,
          "parseErrors": 0,
          "locked": 0
      },
      "description": "Found matching items."
  }

Episodes of a podcast

results = index.episodesByFeedId(522613)
results = index.episodesByFeedUrl("http://feed.thisamericanlife.org/talpodcast")
results = index.episodesByItunesId(201671138)

results = index.episodesByFeedId(522613, since=-525600)  # in the last year
results = index.episodesByFeedId(522613, since=1577836800)  # Jan 1st 2020
Click to see sample result!
  {
      "status": "true",
      "items": [
          {
              "id": 1270106072,
              "title": "726: Twenty-Five",
              "link": "http://feed.thisamericanlife.org/~r/talpodcast/~3/p41tfsPlK00/twenty-five",
              "description": "To commemorate our show\u2019s 25th year, we have a program about people who were born the year our show went on\u00a0the\u00a0air.",
              "guid": "44678 at https://www.thisamericanlife.org",
              "datePublished": 1607900400,
              "datePublishedPretty": "December 13, 2020 5:00pm",
              "dateCrawled": 1607927945,
              "enclosureUrl": "https://www.podtrac.com/pts/redirect.mp3/podcast.thisamericanlife.org/podcast/726.mp3",
              "enclosureType": "audio/mpeg",
              "enclosureLength": 0,
              "duration": 3561,
              "explicit": 0,
              "episode": null,
              "episodeType": null,
              "season": 0,
              "image": "",
              "feedItunesId": 201671138,
              "feedImage": "https://files.thisamericanlife.org/sites/all/themes/thislife/img/tal-name-1400x1400.png",
              "feedId": 522613,
              "feedLanguage": "en",
              "chaptersUrl": null,
              "transcriptUrl": null
          },
          ...
      ],
      "count": 28,
      "query": "201671138",
      "description": "Found matching items."
  }

Episode by ID

results = index.episodeById(1270106072)
Click to see sample result!
  {
      "status": "true",
      "id": "1270106072",
      "episode": {
          "id": 1270106072,
          "title": "726: Twenty-Five",
          "link": "http://feed.thisamericanlife.org/~r/talpodcast/~3/p41tfsPlK00/twenty-five",
          "description": "To commemorate our show\u2019s 25th year, we have a program about people who were born the year our show went on\u00a0the\u00a0air.",
          "guid": "44678 at https://www.thisamericanlife.org",
          "datePublished": 1607900400,
          "datePublishedPretty": "December 13, 2020 5:00pm",
          "dateCrawled": 1607927945,
          "enclosureUrl": "https://www.podtrac.com/pts/redirect.mp3/podcast.thisamericanlife.org/podcast/726.mp3",
          "enclosureType": "audio/mpeg",
          "enclosureLength": 0,
          "duration": 3561,
          "explicit": 0,
          "episode": null,
          "episodeType": null,
          "season": 0,
          "image": "",
          "feedItunesId": 201671138,
          "feedImage": "https://files.thisamericanlife.org/sites/all/themes/thislife/img/tal-name-1400x1400.png",
          "feedId": 522613,
          "feedTitle": "This American Life",
          "feedLanguage": "en",
          "chaptersUrl": null,
          "transcriptUrl": null
      },
      "description": "Found matching item."
  }

Recent episodes

results = index.recentEpisodes(max=5, excluding="trump", before_episode_id=1270106072)
Click to see sample result!
  {
      "status": "true",
      "items": [
          {
              "id": 1269804903,
              "title": "How epidemics and pandemics have changed history",
              "link": "http://www.abc.net.au/radionational/programs/rearvision/how-epidemics-and-pandemics-have-changed-history/12851986",
              "description": "Human history is usually understood through wars, economic changes, technological development or great leaders. What\u2019s frequently overlooked is the role of infectious disease epidemics and pandemics. But as the COVID-19 virus has reminded us, disease can change us in ways we could never imagine.",
              "guid": "http://www.abc.net.au/radionational/programs/rearvision/how-epidemics-and-pandemics-have-changed-history/12851986",
              "datePublished": 1608426300,
              "datePublishedPretty": "December 19, 2020 7:05pm",
              "dateCrawled": 1607923316,
              "enclosureUrl": "http://mpegmedia.abc.net.au/rn/podcast/2020/12/rvn_20201220.mp3",
              "enclosureType": "audio/mp3",
              "enclosureLength": 27955968,
              "explicit": 0,
              "episode": null,
              "episodeType": null,
              "season": 0,
              "image": "",
              "feedItunesId": 135114451,
              "feedImage": "http://www.abc.net.au/cm/rimage/9860262-1x1-thumbnail.jpg?v=2",
              "feedId": 990878,
              "feedTitle": "Rear Vision",
              "feedLanguage": "en-AU"
          },
          ...
      ],
      "count": 5,
      "max": "5",
      "description": "Found matching items."
  }

Running the tests

  • Export the api key and secret
export PODCAST_INDEX_API_KEY="7B3U8VVP87QWSZUFXJRE"
export PODCAST_INDEX_API_SECRET="4QwK83LA7RttCDdms9MnCn3HMYqGPG6CDEvnkL2w"
  • Run the tests
coverage run -m pytest --log-cli-level=INFO

Contributing

  • Fork the repo
  • Add your awesome code
  • Submit a pull request
  • Ensure all existing tests pass
  • Bonus: include tests for your awesome new feature

Updating the pip package

This is mostly for myself since I have to lookup these commands every time ;)

  1. Update version number in setup.py
  2. Run the following commands
rm -rf build
rm -rf dist
python3 -m pip install --upgrade build
python3 -m build
  1. Check that there is a .tar.gz and .whl file in the dist folder
  2. Upload the new version
python3 -m pip install --upgrade twine
twine upload dist/*

Support

I am passionate about podcasting and work on this in my spare time. Hit me up and we can grab a virtual coffee together.

Buy Me A Coffee

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

python_podcastindex-1.15.0.tar.gz (13.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

python_podcastindex-1.15.0-py3-none-any.whl (9.4 kB view details)

Uploaded Python 3

File details

Details for the file python_podcastindex-1.15.0.tar.gz.

File metadata

  • Download URL: python_podcastindex-1.15.0.tar.gz
  • Upload date:
  • Size: 13.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for python_podcastindex-1.15.0.tar.gz
Algorithm Hash digest
SHA256 e937f1c3a5702284204a6f584c919de7175fc304628e9411dcc98dc2a52a3417
MD5 3e3423fb7d4bea38d49e3466b29ebd7c
BLAKE2b-256 6d8c39f08159fc87c540c6d90daf61323c5026bf4e0aa1f395548394fdc70c36

See more details on using hashes here.

File details

Details for the file python_podcastindex-1.15.0-py3-none-any.whl.

File metadata

File hashes

Hashes for python_podcastindex-1.15.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f1651d05887ccc6cb6d8bdaf65cbce815f33ad2106447b682ec6776918b04cfb
MD5 b8dfbb2138d893c4b27713bca1f37d39
BLAKE2b-256 35b3daa8db3493e9ef090041fa878cabad7011843a1520cb48c1b5388ce69222

See more details on using hashes here.

Supported by

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