Skip to main content

A library to access the Project Gutenberg API

Project description

py-gutenberg

Install from pip Tests Status Build Status License Latest Release Version Number Supported Python Versions

Overview

The py-gutenberg package is a Python library that provides methods to access the Project Gutenberg library. Users can search for books based on a variety of metadata, get full texts in various formats, and retrieve metadata for books by their ID number.

Installation

⚠️ This package has only been tested on Python 3.7 and above. There are no plans for a Python 2 version.

The package can be installed using the pip package manager:

pip install py-gutenberg

Usage

You should import the module like so:

from gutenberg import GutenbergAPI

The GutenbergAPI constructor defaults to using a public instance of the Gutendex API, hosted by me at https://gutendex.devbranch.co. If you are self-hosting the API, you can specify the IP address or URL of your instance with the instance_url parameter.

# Uses the public instance
gb = GutenbergAPI()
# Uses a self-hosted instance
gb_private = GutenbergAPI(instance_url="https://gutendex.yourdomain.com")

Book Lists and Searching

Here's a simple example to get a list of the most recently uploaded books:

gb.get_all_books()

Or, to get only public domain books:

gb.get_public_domain_books()

Individual Books

To get an individual book's metadata:

gb.get_book_metadata()

Or, to get the full text of a book:

gb.get_book_text()

Full usage information is available in the documentation

Thanks

This module is built on the wonderful but unofficial API built by @garethbjohnson known as Gutendex. By default, this library uses a public instance I'm hosting myself, but does not have the bandwidth to maintain more than a few concurrent users. Please be kind and limit your requests where possible. Additionally, if you intend to use this library in a production environment, I highly encourage you to self-host.

Read about self-hosting the API here!

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

py-gutenberg-1.0.3.tar.gz (5.2 kB view details)

Uploaded Source

Built Distribution

py_gutenberg-1.0.3-py3-none-any.whl (5.6 kB view details)

Uploaded Python 3

File details

Details for the file py-gutenberg-1.0.3.tar.gz.

File metadata

  • Download URL: py-gutenberg-1.0.3.tar.gz
  • Upload date:
  • Size: 5.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.3

File hashes

Hashes for py-gutenberg-1.0.3.tar.gz
Algorithm Hash digest
SHA256 b6a79b194e30672b4fdfa80128c79a0c8285e72ea01ab35e9805618d24fbd94e
MD5 6cff45d7e363775df9f7d5ddf474ae78
BLAKE2b-256 9ef00092b62f488dcaf0cd5d333628ddee2c7994a8f0c4a4ebadf2ba27c8ad77

See more details on using hashes here.

File details

Details for the file py_gutenberg-1.0.3-py3-none-any.whl.

File metadata

File hashes

Hashes for py_gutenberg-1.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 2ab5b1444a7e32b7eb0e59004416b8ae587d59002f06523a29fc7a862fdeaa82
MD5 b9438fd1c18b48f57b24f994b06b0329
BLAKE2b-256 01eb97868007d7befb1ac624d29ad81007604404164be34192d68efb4c3b462b

See more details on using hashes here.

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