Skip to main content

Python module for interacting with Library of Congress Linked Data Service and API endpoint

Project description

loc-authorities

unit tests

Python library for querying and representing LoC ID APIs. The library provides connectors for the Library of Congress Linked Data Authority.

loc-authorities uses the python library rdflib to query Library of Congress entities and represent them as python classes.

Supported search interfaces:

Fully supported authorities:

Partially supported authorities:

There are no plans to support further authorities at this point in time, but pull requests for implementations of other authorities are welcome!

Installation

Via pip into virtual environment

Clone the repo, then in the base directory, run:

$ pip install .

Usage

# construct URIs

>>>
>>> from loc_authorities.api import LocAPI
>>> LocAPI.uri_from_id('n79043402')
'http://id.loc.gov/authorities/n79043402'

>>>
>>> LocAPI.dataset_uri_from_id('n79043402')
'http://id.loc.gov/authorities/names/n79043402'

# Query LoC search endpoints

>>>
>>> loc = LocAPI()
>>> loc.retrieve_label('Franklin, Benjamin, 1706-1790')
'n79043402'

# query the left-anchored search through the method "suggest"
# returns list of top ten results from API
>>>
>>> suggest = loc.suggest('Franklin, Benjamin')
>>> suggest[0].uri
'http://id.loc.gov/authorities/names/n2015067702'
>>> suggest[0].label
'Franklin Benjamin'

# method LocAPI.search() queries the keyword search method in the same manner

# Represent a single entity
>>>
>>> from loc_authorities.api import LocEntity
>>> entity = LocEntity('mp2013015202')
>>> entity.authoritative_label
rdflib.term.Literal('dancer', lang='en')
>>> entity.dataset_uri
'http://id.loc.gov/authorities/performanceMediums/mp2013015202'
>>> entity.instance_of
[
    rdflib.term.URIRef('http://www.loc.gov/mads/rdf/v1#Medium'),
    rdflib.term.URIRef('http://www.loc.gov/mads/rdf/v1#Authority'),
    rdflib.term.URIRef('http://www.w3.org/2004/02/skos/core#Concept')
]

# Represent an entity from the Name Authority
>>>
>>> from loc_authorities.api import NameEntity
>>> name = NameEntity('n79043402')
>>> name.authoritative_label
rdflib.term.Literal('Franklin, Benjamin, 1706-1790') # inherits all properties of LocEntity
>>> name.birthdate
rdflib.term.Literal('1706-01-17', datatype=rdflib.term.URIRef('http://id.loc.gov/datatypes/edtf/EDTF'))
>>> name.birthyear
1706
>>> name.deathdate
rdflib.term.Literal('1790-04-17', datatype=rdflib.term.URIRef('http://id.loc.gov/datatypes/edtf/EDTF'))
>>> name.deathyear
1790

# Represent an entity from the Subject Authority
>>>
>>> from loc_authorities.api import SubjectEntity
>>> subject = SubjectEntity('sh85054401')
>>> subject.authoritative_label
rdflib.term.Literal('German literature--Germany (East)', lang='en') # inherits all properties of LocEntity
# for complex subjects, components instances of either NameEntity or SubjectEntity
>>> subject.components
[<loc_authorities.api.SubjectEntity object at 0x0000025AF492B810>, <loc_authorities.api.NameEntity object at 0x0000025AF492A990>]

Running tests

Install development requirements
$ pip install . --group dev

Run tests with pytest
$ python -m pytest

Build documentation

Install development requirements $ pip install . --group dev

Run doctest to make sure the code examples work $ make -C docs doctest

Build documentation with Sphinx $ sphinx-build ./docs/source ./docs/build

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

loc_authorities-0.1.0.tar.gz (62.6 kB view details)

Uploaded Source

Built Distribution

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

loc_authorities-0.1.0-py3-none-any.whl (10.9 kB view details)

Uploaded Python 3

File details

Details for the file loc_authorities-0.1.0.tar.gz.

File metadata

  • Download URL: loc_authorities-0.1.0.tar.gz
  • Upload date:
  • Size: 62.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.5

File hashes

Hashes for loc_authorities-0.1.0.tar.gz
Algorithm Hash digest
SHA256 89113ed905fdb494ae57e4ad69e380ef7ad9846ee4c43c00973f01773fdad0de
MD5 cc95c5cc85064475a70531f01209d759
BLAKE2b-256 d998d71ea6d4453f00d0862ffc55b7a2859245a254c2e042102eaebc9bcd8c84

See more details on using hashes here.

File details

Details for the file loc_authorities-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for loc_authorities-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 469d9e219d7705e98098c0d1d5d3238157468e9d99a93b8c1627aea3babf52a5
MD5 94216cf628bbca268b0f57ef07c9ffdd
BLAKE2b-256 1fe516358f43136253940d0a86080d3fedcdb5d2d3c2d86132a65825aa281bb3

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