Skip to main content

A Python feed reader library.

Project description

reader is a Python feed reader library.

It is designed to allow writing feed reader applications without any business code, and without depending on a particular framework.

build status (GitHub Actions) code coverage documentation status PyPI status checked with mypy code style: black

reader allows you to:

  • retrieve, store, and manage Atom, RSS, and JSON feeds

  • mark articles as read or important

  • add arbitrary tags/metadata to feeds and articles

  • filter feeds and articles

  • full-text search articles

  • get statistics on feed and user activity

  • write plugins to extend its functionality

  • skip all the low level stuff and focus on what makes your feed reader different

…all these with:

  • a stable, clearly documented API

  • excellent test coverage

  • fully typed Python

What reader doesn’t do:

  • provide an UI

  • provide a REST API (yet)

  • depend on a web framework

  • have an opinion of how/where you use it

The following exist, but are optional (and frankly, a bit unpolished):

  • a minimal web interface

    • that works even with text-only browsers

    • with automatic tag fixing for podcasts (MP3 enclosures)

  • a command-line interface

Documentation: reader.readthedocs.io

Usage:

$ pip install reader
>>> from reader import make_reader
>>>
>>> reader = make_reader('db.sqlite')
>>> reader.add_feed('http://www.hellointernet.fm/podcast?format=rss')
>>> reader.update_feeds()
>>>
>>> entries = list(reader.get_entries())
>>> [e.title for e in entries]
['H.I. #108: Project Cyclops', 'H.I. #107: One Year of Weird', ...]
>>>
>>> reader.mark_entry_as_read(entries[0])
>>>
>>> [e.title for e in reader.get_entries(read=False)]
['H.I. #107: One Year of Weird', 'H.I. #106: Water on Mars', ...]
>>> [e.title for e in reader.get_entries(read=True)]
['H.I. #108: Project Cyclops']
>>>
>>> reader.update_search()
>>>
>>> for e in reader.search_entries('year', limit=3):
...     title = e.metadata.get('.title')
...     print(title.value, title.highlights)
...
H.I. #107: One Year of Weird (slice(15, 19, None),)
H.I. #52: 20,000 Years of Torment (slice(17, 22, None),)
H.I. #83: The Best Kind of Prison ()

Project details


Release history Release notifications | RSS feed

This version

3.21

Download files

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

Source Distribution

reader-3.21.tar.gz (1.7 MB view details)

Uploaded Source

Built Distribution

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

reader-3.21-py3-none-any.whl (266.4 kB view details)

Uploaded Python 3

File details

Details for the file reader-3.21.tar.gz.

File metadata

  • Download URL: reader-3.21.tar.gz
  • Upload date:
  • Size: 1.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for reader-3.21.tar.gz
Algorithm Hash digest
SHA256 d1603a5d318650a02b32e42bc3fbd5bc9639a0d241a9fc4f87af70639acaa2ce
MD5 8bfee8b4d2acabf09c3c934f00fa3978
BLAKE2b-256 58d3bfa8ebd32b955bd8a535f3d066f316b1f4c431ab5087cd8075dc9a591df4

See more details on using hashes here.

Provenance

The following attestation bundles were made for reader-3.21.tar.gz:

Publisher: publish.yaml on lemon24/reader

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file reader-3.21-py3-none-any.whl.

File metadata

  • Download URL: reader-3.21-py3-none-any.whl
  • Upload date:
  • Size: 266.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for reader-3.21-py3-none-any.whl
Algorithm Hash digest
SHA256 29ad434b63e49c459a3ff22db89a6fc9e57b0546fa11225c6d285989e04310c4
MD5 6f97f6a8c9a2fa9d0345bcc1a2abd58b
BLAKE2b-256 359171b578a5d3d512757b83623eb775a18dbe7f019fa5cee078295ec243270a

See more details on using hashes here.

Provenance

The following attestation bundles were made for reader-3.21-py3-none-any.whl:

Publisher: publish.yaml on lemon24/reader

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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