Skip to main content

Engage with your Readwise Reader library through your command-line.

Project description

Reader API Command-Line Interface

This repository provides a command-line interface (CLI) for interacting with Readwise's Reader API. This tool allows you to interact with the API directly from your command line, making it easy to add and list documents from your Reader library.

Also, you can upload documents from your browser reading list, such as Chrome ReadingList.

Please note that future updates will include support for additional browsers.

Installation

Set up a virtual environment and then run:

pip install readwise-reader-cli

Usage

Before using the CLI, make sure to set the READER_API_TOKEN environment variable. You can obtain your API token here.

export READER_API_TOKEN={your_api_token}

The CLI provides the following commands:

Usage: python -m readercli [OPTIONS] COMMAND [ARGS]...

  Interact with your Reader Library

Options:
  --help  Show this message and exit.

Commands:
  add       Add Document
  lib       Library breakdown
  list      List Documents
  upload    Upload Reading List File
  validate  Validate token

List Documents

Usage: python -m readercli list [OPTIONS]

  List Documents

Options:
  -l, --location [new|archive|later|feed]
                                  Document(s) location
  -c, --category [article|tweet|pdf|epub|email|note|video|highlight|rss]
                                  Document(s) category
  -a, --update-after [%Y-%m-%d|%Y-%m-%dT%H:%M:%S|%Y-%m-%d %H:%M:%S]
                                  Updated after date in ISO format. Default:
                                  last 24hrs.
  -d, --date-range TEXT           View documents updated after choosen time:
                                  today, week, month.
  -L, --layout [table|list]       Display documents either as a list or table.
                                  Default: table.
  -n, --num-results INTEGER       The number of documents to show.
  -P, --pager                     Use to page output.
  --help                          Show this message and exit.

Examples:

python -m readercli list --location archive
python -m readercli list --location archive --category article
python -m readercli list --location archive --category article --update-after 2023-01-01
python -m readercli list --location archive --category article --update-after 2023-01-01 --layout list
python -m readercli list --location archive --category article --date-range week

Layouts

table

list_table

Upload a Reading List (Google Chrome support only)

THINGS TO NOTE:

  • RATE LIMIT - Due to Reader's API rate limit of 20 requests per minute, a larger list will take a few minutes to upload.

  • LACK OF READING LIST APIs - There is no API to pull your ReadingList from Google, but it is being looked at here.

To upload your Chrome Reading List, you first need to download your data from your account, then follow these steps:

  1. Navigate to the Data & Privacy section.
  2. Find the "Download your data" option and click on it.
  3. A list of data to export will appear. Click "Deselect all" and then locate the Chrome section.
  4. Click "All Chrome data Included" and select ONLY "ReadingList".
  5. Save the downloaded .html file to your preferred directory and take note of the file path.
  6. Run the import command.
Usage: python -m readercli upload [OPTIONS] INPUT_FILE

  Upload Reading List File

Options:
  --file-type [html|csv]
  --help                  Show this message and exit.

Examples:

python -m readercli upload /path/to/ReadingList.html
python -m readercli upload --file-type csv /path/to/ReadingList.csv

Add Document

Usage: python -m readercli add [OPTIONS] URL

  Add Document

Options:
  --help  Show this message and exit.

Example:

python -m readercli add http://www.example.com

Library Overview

Usage: python -m readercli lib [OPTIONS]

  Library breakdown

Options:
  -V, --view [category|location|tags]
  --help                          Show this message and exit.
python -m readercli lib

  Category Breakdown
┏━━━━━━━━━━━━━┳━━━━━━━┓
┃ Name         Count ┃
┡━━━━━━━━━━━━━╇━━━━━━━┩
│ 🖍️ highlight│   724 │
│ 📡️ rss         391 │
│ ✉️ email        363 │
│ 📰️ article     264 │
│ 📝️ note        140 │
│ 📄️ pdf          83 │
│ 🐦️ tweet        25 │
│ 📹️ video        10 │
│ 📖️ epub          0 │
└─────────────┴───────┘

python -m readercli lib --view [location | tags]

 Location Breakdown
┏━━━━━━━━━━━┳━━━━━━━┓
┃ Name       Count ┃
┡━━━━━━━━━━━╇━━━━━━━┩
│ 🗄️ archive│  1124 │
│ 🕑️ later     241 │
│ ⭐️ new        10 │
│ 📥️ feed        2 │
└───────────┴───────┘

python -m readercli lib --view tags

Tags Breakdown
┏━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━┓
┃ Name                    Count ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━┩
│ python                     32 │
│ documentation               9 │
│ programming                 7 │
│ github                      7 │
│ git                         6 │
│ packages                    6 │
│ design-patterns             6 │
│ mac                         1 │
└────────────────────────┴───────┘

Validate Token

Usage: python -m readercli validate [OPTIONS] TOKEN

  Validate token

Options:
  --help  Show this message and exit.

Main Third-Party Libraries

Inspiration

License

This project is licensed under the MIT License - see the LICENSE file for details.

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

readwise_reader_cli-1.0.0.tar.gz (15.6 kB view hashes)

Uploaded Source

Built Distribution

readwise_reader_cli-1.0.0-py3-none-any.whl (17.2 kB view hashes)

Uploaded Python 3

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