Skip to main content

bookmuse generates personalized reading lists based on user preferences and reading history.

Project description

bookmuse

PyPI version License: MIT Downloads LinkedIn

A personalized reading list generator that creates tailored book recommendations based on user preferences and reading history.

Overview

bookmuse is a Python package designed to help users discover new books that match their interests. Users provide a text input describing their favorite genres, interests, or books they've enjoyed, and bookmuse produces a structured list of recommended books, including titles, authors, and brief descriptions. This tool streamlines the process of finding your next great read by delivering curated suggestions in a clear and consistent format.

Installation

Install the package via pip:

pip install bookmuse

Usage

from bookmuse import bookmuse

# Example user input describing preferences
user_input = "I'm interested in science fiction and fantasy, especially space operas and epic adventures."

# Using the default LLM (ChatLLM7)
recommendations = bookmuse(user_input)

# Using a custom LLM instance (e.g., OpenAI)
from langchain_openai import ChatOpenAI

llm = ChatOpenAI()
recommendations = bookmuse(user_input, llm=llm)

Parameters

  • user_input (str): The descriptive text of user preferences.
  • llm (BaseChatModel, optional): An instance of a language model. Defaults to ChatLLM7 from langchain_llm7.
  • api_key (str, optional): API key for the language model. If not provided, it attempts to use the LLM7_API_KEY environment variable or defaults to "None".

Details

The package uses ChatLLM7 from the langchain_llm7 library by default. Developers can pass their own language model instances compatible with the expected interface, such as:

from langchain_openai import ChatOpenAI
from bookmuse import bookmuse

llm = ChatOpenAI()
response = bookmuse(user_input, llm=llm)

or

from langchain_anthropic import ChatAnthropic
from bookmuse import bookmuse

llm = ChatAnthropic()
response = bookmuse(user_input, llm=llm)

or

from langchain_google_genai import ChatGoogleGenerativeAI
from bookmuse import bookmuse

llm = ChatGoogleGenerativeAI()
response = bookmuse(user_input, llm=llm)

Rate Limits

For most use cases, the default free-tier rate limits of LLM7 are sufficient. For higher rate limits, set your API key via the environment variable LLM7_API_KEY or pass it directly:

recommendations = bookmuse(user_input, api_key="your_api_key")

You can register for a free API key at https://token.llm7.io/.

Support & Issues

If you encounter any issues or have questions, please open an issue on the GitHub repository:
https://github.com/chigwell/bookmuse

Author

Eugene Evstafev
Email: hi@eugene.plus
GitHub: chigwell

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

bookmuse-2025.12.22083751.tar.gz (5.2 kB view details)

Uploaded Source

Built Distribution

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

bookmuse-2025.12.22083751-py3-none-any.whl (5.7 kB view details)

Uploaded Python 3

File details

Details for the file bookmuse-2025.12.22083751.tar.gz.

File metadata

  • Download URL: bookmuse-2025.12.22083751.tar.gz
  • Upload date:
  • Size: 5.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.1

File hashes

Hashes for bookmuse-2025.12.22083751.tar.gz
Algorithm Hash digest
SHA256 b7cfff9a6f67a8564410e87e9ec1bdeed88d155f83caf35580acb1edaf000dde
MD5 e7f309bf12934fc8b992ecf4f10e2a9a
BLAKE2b-256 837bc3e30227068f38599d9786b6c7cd782b60f56a72167b8d51de2ffc021e05

See more details on using hashes here.

File details

Details for the file bookmuse-2025.12.22083751-py3-none-any.whl.

File metadata

File hashes

Hashes for bookmuse-2025.12.22083751-py3-none-any.whl
Algorithm Hash digest
SHA256 ce94b3546ef4d8e618427a357d1f0c6a458126d44cd0ae9d47f2674c8bf96e49
MD5 9cb77a3c87471422ae1dc914026adc7d
BLAKE2b-256 b5e35c1eb52e914ab0b78fa408031ed541af73f594d1bf682fe850859972bcdd

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