loc-catalog/SKILL.md
Search the Library of Congress digital collections via the loc.gov JSON API. Use this skill whenever the user wants to search LOC's digitized books, photos, maps, manuscripts, newspapers, audio, or film/video, look up items by LCCN, browse LOC collections, find primary sources with date range filters, or retrieve citations and download links for LOC materials. Also triggers when cross-referencing items found in other library catalogs against LOC holdings.
npx skillsauth add kltng/humanities-skills loc-catalogInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Search and retrieve items from LOC's digitized collections — books, photos, maps, manuscripts, newspapers, audio, and more.
The loc.gov JSON API searches LOC's digitized and online collections — not the full OPAC. By default, only digitized items are returned. Add all=true to include non-digitized catalog records.
fo=json parameter, NOT a URL extensionUnlike LibraryCloud (.json extension), LOC uses a query parameter:
CORRECT: https://www.loc.gov/search/?q=hamlet&fo=json
WRONG: https://www.loc.gov/search.json?q=hamlet
fa= with pipe separatorsSingle: ?fa=subject:physics
Multiple: ?fa=subject:wildlife|location:yellowstone
Available facet fields: subject, contributor, location, language, original-format, online-format, partof, digitized, access-restricted.
/books/, /photos/, /maps/, /audio/, /newspapers/, /manuscripts/, /film-and-videos/, /notated-music/ all accept the same params as /search/.
| Param | Description | Example |
|-------|-------------|---------|
| q | Keyword search | q=hamlet+shakespeare |
| fa | Facet filter | fa=subject:physics\|language:english |
| dates | Date range (YYYY/YYYY) | dates=1920/1940 |
| c | Results per page (25, 50, 100, 150) | c=50 |
| sp | Page number (starts at 1) | sp=2 |
| sb | Sort: date, date_desc, title_s, title_s_desc | sb=date_desc |
| all | Include non-digitized (true/false) | all=true |
| at | Select attributes (comma-sep) | at=item,resources |
| fo | Format: json or yaml | fo=json |
https://www.loc.gov/item/{LCCN}/?fo=json
Returns full item detail including cite_this (APA/Chicago/MLA citations), resources (download links), other_formats (MARCXML, MODS, Dublin Core).
{
"results": [
{
"id": "http://www.loc.gov/item/95521789/",
"title": "Item title",
"date": "1796-01-01",
"contributor": ["Name"],
"subject": ["Subject term"],
"language": ["English"],
"original_format": ["book"],
"description": ["..."],
"image_url": ["//tile.loc.gov/..."],
"digitized": true,
"number_lccn": ["95521789"]
}
],
"pagination": {
"of": 85604,
"total": 17121,
"perpage": 5,
"current": 1
},
"facets": { ... }
}
The item object adds: call_number, created_published, rights, summary, stmt_of_responsibility, genre, and cite_this with pre-formatted citations.
from scripts.loc_api import LocAPI
loc = LocAPI()
# Keyword search
results = loc.search("hamlet shakespeare", limit=10)
# Format-specific
photos = loc.search("civil war", format="photos", dates="1860/1865")
# Faceted search
results = loc.search("wildlife", facets={"subject": "birds", "location": "yellowstone"})
# Item lookup
item = loc.get_item("95521789")
citation = loc.get_citation(item, style="apa")
# Browse collections
collections = loc.list_collections()
items = loc.browse_collection("civil-war-maps", limit=20)
# Summarize
for r in results[:5]:
print(loc.summarize(r))
c=150)references/api_reference.md — Complete parameter and response field referencescripts/loc_api.py — Python client with search, item lookup, collection browsing, and citation extractiondevelopment
Query the China Biographical Database (CBDB) locally via SQLite for biographical data on 656K+ historical Chinese figures from the 7th century BCE through the 19th century CE. Use when searching for Chinese historical figures, scholars, officials, or literary figures — their biographical details, family/kinship networks, official postings, social associations, examination records, or addresses. Runs entirely locally after initial database download (~556 MB). Faster and more flexible than the API version.
development
Interact with a local Zotero 8 desktop application through its HTTP API at localhost:23119. Use this skill whenever the user wants to search, fetch, add, edit, or organize bibliographic items in their Zotero library, import citations (BibTeX, RIS, etc.), attach files, manage collections and tags, or retrieve full-text content from Zotero. Triggers on mentions of Zotero, citation management, reference libraries, bibliographic databases, or local library management. Also use when chaining with other catalog skills (Harvard, LOC, HathiTrust, etc.) to save found records into the user's Zotero library.
development
Search for items and properties on Wikidata and retrieve entity details, claims, and external identifiers. Supports both keyword search (Wikidata Action API) and semantic/hybrid search (Wikidata Vector Database), plus direct entity retrieval (Special:EntityData) and structured querying (WDQS SPARQL).
testing
Query and explore the TGAZ (Temporal Gazetteer) SQLite database of 82,000+ historical Chinese placenames spanning 763 BCE to 1911 CE. Use this skill whenever the user asks about historical Chinese places, administrative geography, dynastic jurisdictions, place name evolution, or wants to query tgaz.db. Also trigger when the user mentions CHGIS, TGAZ, historical gazetteer, Chinese historical GIS, or asks questions like "what was X called in dynasty Y", "what counties existed in year Z", "where was X located", or any spatial/temporal query about Chinese historical geography. This skill is relevant even for casual questions like "tell me about ancient Chang'an" or "Tang dynasty cities near the Yellow River".