Skip to main content

Cover image finder: find a cover image given a book identifier

Project description

Coif

Coif (Cover image finder) is a Python 3 module for contacting multiple services to look for a book jacket image given an identifier such as an ISBN.

License Latest release DOI PyPI

Table of contents

Introduction

In a variety of situations involving library software systems, it's useful to show a small image of a book's cover or jacket. Coif (Cover image finder) is a simple Python 3 library that looks for cover images using multiple network services. When it finds one, Coif returns the image in JPEG format.

Coif is most similar to bookcovers, a JavaScript library that performs federated search for book cover images. A Python package similar to Coif is booker, but that one is limited to searching Google Books.

Installation

The instructions below assume you have a Python interpreter installed on your computer; if that's not the case, please first install Python version 3 and familiarize yourself with running Python programs on your system.

On Linux, macOS, and Windows operating systems, you should be able to install coif with pip. To install coif from the Python package repository (PyPI), run the following command:

python3 -m pip install coif

As an alternative to getting it from PyPI, you can use pip to install coif directly from GitHub, like this:

python3 -m pip install git+https://github.com/caltechlibrary/coif.git

Usage

Coif currently offers only an application programming interface (API); it does not offer a command-line interface. The main interface point is the function cover_image(...). Here is a simple demonstration of using it:

from coif import cover_image

(url, image) = cover_image('9781479837243')
if image:
    with open('image.jpg', 'wb') as image_file:
        image_file.write(image)
else:
    print('Unable to find image')

As illustrated above, cover_image returns two values: a URL, and a JPEG image in binary form (if a cover image is found).

Arguments to cover_image

The function takes one required argument, an identifier (preferably an ISBN, but possibly other kinds of identifiers), and additional optional arguments. In more detail, the possible arguments are:

  • identifier (required): an ISBN, OCLC id, LCCN id, OLID and or Open Library Cover ID. Note that only Open Library accepts anything other than ISBN, so your best bet for finding a cover image is to use an ISBN. Conversely, if you provide anything other than an ISBN, cover_image will only contact Open Library.
  • kind (optional): the kind of identifier given as the first argument. Recognized values are isbn, lccn, olid, oclc, and coverid. The default is isbn.
  • size (optional): one of the letters S, M, or L, to indicate a preference for small, medium, or large images, respectively. Some cover images may exist in one size and not another, and there is no way to know in advance which size may be available from a service without actually downloading the image. If a size is provided, cover_image will ask for that size and smaller; for example, if you call it with size = 'M', it will try to find M first and if none exists, it will try S. By default, it wil only try S. If you want to get the largest image you can find, call it with size = 'L'.
  • cc_login (optional): one of the best services for finding cover images is Content Cafè 2 from Baker & Talor, but it requires an account. If you have a user id and password with their service, provide the credentials as a tuple of values ("user", "password") to the optional argument cc_login.

Why cover_image always returns an image

A frustrating aspect of many of the services is that they provide no way to simply ask whether an image exists. If the services do not have an image for a given identifier, most return a small placeholder image (often containing rendered text to the effect of "no cover found") instead of returning a failure code of some kind. Consequently, cover_image must always download images and test them against some size thresholds to determine if it got a placeholder or an actual cover image. This is the reason why the return values from cover_image are both a URL and an image: it has already downloaded the image, so it may as well return it, to save the caller the trouble of downloading the image a second time.

Known issues and limitations

Although the Open Library Covers API accepts multiple types of identifiers such as an ISBN, OCLC, LCCN, and more, other services only accept ISBNs. Thus, while you can pass any of these types of identifiers to Coif, if what you use is not an ISBN, then Coif will only contact the Open Library's service.

Getting help

If you find an issue, please submit it in the GitHub issue tracker for this repository.

Contributing

We would be happy to receive your help and participation with enhancing Coif! Please visit the guidelines for contributing for some tips on getting started.

License

Software produced by the Caltech Library is Copyright © 2021 California Institute of Technology. This software is freely distributed under a BSD/MIT type license. Please see the LICENSE file for more information.

Authors and history

In this section, list the authors and contributors to your software project. Adding additional notes here about the history of the project can make it more interesting and compelling. This is also a place where you can acknowledge other contributions to the work and the use of other people's software or tools.

Acknowledgments

This work was funded by the California Institute of Technology Library.

The vector artwork of a man's coiffure, used as the icon for this project, was created by sarah from the Noun Project. It is licensed under the Creative Commons CC-BY 3.0 license. I edited the logo in Boxy SVG, a native SVG editor for macOS to change the icon color to the orange used by Caltech in their logo.

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

coif-0.0.1.tar.gz (8.6 kB view details)

Uploaded Source

Built Distribution

coif-0.0.1-py3-none-any.whl (8.6 kB view details)

Uploaded Python 3

File details

Details for the file coif-0.0.1.tar.gz.

File metadata

  • Download URL: coif-0.0.1.tar.gz
  • Upload date:
  • Size: 8.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.25.1 setuptools/57.0.0 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.9.5

File hashes

Hashes for coif-0.0.1.tar.gz
Algorithm Hash digest
SHA256 194d3b3e9165f10ad688ec969f29bd1097d7f4af1b38b22f84a7b47ee1778d2c
MD5 8714cdfb20debeee654c3b900b6c9a1d
BLAKE2b-256 83b9fb259d2594b7190d99ed27a98081f2415938837dd62d212ccae5a940cad3

See more details on using hashes here.

File details

Details for the file coif-0.0.1-py3-none-any.whl.

File metadata

  • Download URL: coif-0.0.1-py3-none-any.whl
  • Upload date:
  • Size: 8.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.25.1 setuptools/57.0.0 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.9.5

File hashes

Hashes for coif-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 93c21f51fe0ab895e717b951035b0bbf9816486fc6214cbfd278d713a0ea07cd
MD5 f2bcd8cf41e5bbd807125f218b5480bc
BLAKE2b-256 bfee149f6a08f25ccce5099d4b88c6c27e662fc09bd036d5371e33e948b5da33

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