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; in MVC terms, you’d probably call it a fat model.

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

  • import / export feeds as OPML

  • 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:

  • depend on a web framework

  • have an opinion of how or where you use it

In addition, reader provides:

  • an optional web application based on Flask, Bootstrap, and htmx

  • an optional 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.24

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.24.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.24-py3-none-any.whl (689.3 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for reader-3.24.tar.gz
Algorithm Hash digest
SHA256 fb10bc8912dc276a92802908e85eb5b4bf38c2ea8a1edcb1a414d8e03dbc1446
MD5 7817fdb0c78680d28fb6fd2058ff2f1a
BLAKE2b-256 64f5c69e0283c69b71b0360d4972d524e5b6c41b6704a1c5b5c9da5090272c3c

See more details on using hashes here.

Provenance

The following attestation bundles were made for reader-3.24.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.24-py3-none-any.whl.

File metadata

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

File hashes

Hashes for reader-3.24-py3-none-any.whl
Algorithm Hash digest
SHA256 2cb350304eb0bbf915a5cbdd23abbe4e62a37c04d1fc47a242d2d2d88b7ac37f
MD5 a0ddc20af81feb8ec3aa4ea78129b75a
BLAKE2b-256 544653553b457cbd8b4bdce2f2cafdbb7466921dd079b9b900d476b1d9eed33f

See more details on using hashes here.

Provenance

The following attestation bundles were made for reader-3.24-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