Skip to main content

kathekon is a Python library and CLI tool for fetching Stoic quotes with interpretations.

Project description

kathekon

PyPI Latest Release Pepy Total Downloads GitHub License

kathekon is a Python library and CLI tool for exploring Stoic philosophy through curated quotes. It allows you to fetch random or daily quotes, insert quotes into files like README.md, and generate thoughtful interpretations using OpenAI.


Features

  • Fetch Quotes:

    • Retrieve random Stoic quotes or specific quotes by author or ID.
    • Generate consistent daily quotes based on the day of the year.
    • Fetch multiple quotes at once for broader inspiration.
  • CLI Tool:

    • Display quotes in the terminal with elegant formatting.
    • Update files (e.g., README.md) with quotes and their interpretations.
    • Customize quote fetching using multiple filtering options.
  • OpenAI Integration (Optional):

    • Generate thoughtful interpretations of quotes using OpenAI's GPT models.
  • Library Integration:

    • Use Quotes from the library to integrate Stoic philosophy into your projects.

Installation

Install kathekon using pip:

pip install kathekon

To include OpenAI features, install with the [openai] or [all] extras:

pip install kathekon[openai]
pip install kathekon[all]

Usage

CLI Commands

After installation, you can use the CLI commands kathekon or stoic-quote.

Display a Random Quote

kathekon --author "Marcus Aurelius"

Display Today’s Quote

kathekon daily

Insert a Quote into README.md

Ensure your README.md includes markers like this:

<!--START_SECTION:current-date-->
<!--END_SECTION:current-date-->

<!--START_SECTION:quote-text-->
<!--END_SECTION:quote-text-->

<!--START_SECTION:quote-author-->
<!--END_SECTION:quote-author-->

<!--START_SECTION:quote-interpretation-->
<!--END_SECTION:quote-interpretation-->

Then, insert a random or daily quote:

# Insert a random quote by Marcus Aurelius
kathekon readme random --file README.md --author "Marcus Aurelius"

# Insert today’s Stoic quote
kathekon readme daily --file README.md

Available CLI Arguments

General Options (for default/random quote behavior)

These options can be used when running the CLI without a subcommand, which will display a random quote.

Argument Short Description Default
--id ID -i Fetch a quote by its unique ID. If omitted, a random quote is used. None
--author "Author Name" -a Fetch a random quote by the specified author. If omitted, a random author is chosen. None
--method METHOD -m Choose method to fetch or generate interpretation: gpt, db, gpt+fallback db
--list-authors -l List all available authors and exit. -
--version -v Show version and exit. -

Method Choices Explained

Method Description
gpt Generate a quote interpretation using OpenAI's GPT models. Requires an API key.
db Fetch a (random) existing interpretation from the database.
gpt+fallback Try generating an interpretation using GPT. If unavailable, fall back to a database interpretation.
db+fixed Use a fixed interpretation from the database, ensuring consistency for daily quotes.

daily Command

Displays today’s Stoic quote.

Argument Short Description Default
--method METHOD -m Choose method to fetch or generate interpretation: gpt, db, db+fixed, gpt+fallback db+fixed

readme random Command

Updates the specified file with a random quote.

Argument Short Description Default
--file FILE -f Path to the file to update README.md
--id ID -i Fetch a quote by its unique ID. If omitted, a random quote is used. None
--author "Author Name" -a Fetch a random quote by the specified author. If omitted, a random author is chosen. None
--method METHOD -m Choose method to fetch or generate interpretation: gpt, db, gpt+fallback db

readme daily Command

Updates the specified file with today’s Stoic quote.

Argument Short Description Default
--file FILE -f Path to the file to update README.md
--method METHOD -m Choose method to fetch or generate interpretation: gpt, db, db+fixed, gpt+fallback db+fixed

Library Usage

Fetch a Random Quote

from kathekon import Quotes

quotes = Quotes()
quote = quotes.get_quote(author="Epictetus")
print(f"{quote.text}{quote.author}")

Generate Today’s Quote

daily_quote = quotes.get_daily_quote(method="gpt+fallback")
print(f"{daily_quote.text}{daily_quote.author}")
print(f"Interpretation: {daily_quote.interpretation}")

Fetch Multiple Quotes

You can fetch multiple quotes at once with optional filters like author, limit, or interpretation.

from kathekon import Quotes

quotes = Quotes()

# Fetch up to 5 random quotes
for quote in quotes.get_quotes(limit=5):
    print(f"{quote.text}{quote.author}")

# Fetch 3 quotes by Seneca with interpretations from the database
for quote in quotes.get_quotes(author="Seneca", limit=3, method="db"):
    print(f"{quote.text}{quote.author}")
    print(f"Interpretation: {quote.interpretation}")

OpenAI Integration

To enable OpenAI-powered interpretations, set your API key in the OPENAI_API_KEY environment variable:

export OPENAI_API_KEY="your-api-key"

Then, use the CLI or library to fetch quotes with AI-generated interpretations.


Contributing

Contributions are welcome! Feel free to submit issues or pull requests on the GitHub repository.


Acknowledgements

The Stoic quotes used in this project are sourced from benhoneywill/stoic-quotes.


License

kathekon is licensed under the MIT License. See LICENSE 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

kathekon-0.0.8.tar.gz (3.4 MB view details)

Uploaded Source

Built Distribution

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

kathekon-0.0.8-py3-none-any.whl (3.4 MB view details)

Uploaded Python 3

File details

Details for the file kathekon-0.0.8.tar.gz.

File metadata

  • Download URL: kathekon-0.0.8.tar.gz
  • Upload date:
  • Size: 3.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for kathekon-0.0.8.tar.gz
Algorithm Hash digest
SHA256 32ae4f2fedbc63e677bd8e4a67453c55a94909889d7b81056ba0582640722304
MD5 d8cbda9a9e7ea12bebbd784b1b0c6ef0
BLAKE2b-256 c4034b8b85d683ff68a6e4280f02149c203985c870b22e10557f4e3a0cc7c36a

See more details on using hashes here.

File details

Details for the file kathekon-0.0.8-py3-none-any.whl.

File metadata

  • Download URL: kathekon-0.0.8-py3-none-any.whl
  • Upload date:
  • Size: 3.4 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for kathekon-0.0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 7b6f9def60ef44ef788d53fe5b0ea6139ca0549ac90ab7670ed94fa9b4e64e63
MD5 7f6c08caa4f76c62eb110c4c61b4e1d6
BLAKE2b-256 dac5b2654b5df9f250f50d9cfbbb94c81c0a92580030ac885b2683506f39ff32

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