europeana-collections/SKILL.md
Search Europeana's 50M+ cultural heritage items from 4,000+ European museums, galleries, libraries, and archives. Use this skill whenever the user wants to find European art, manuscripts, photographs, maps, 3D objects, audio, or video from institutions like the Rijksmuseum, British Library, Louvre, or Gallica. Also triggers when searching for open-access European cultural heritage, IIIF resources, or cross-referencing European collections with other library catalogs.
npx skillsauth add kltng/humanities-skills europeana-collectionsInstall 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 50M+ cultural heritage items from 4,000+ European institutions.
api2demo for testingEvery request needs a wskey parameter. The demo key api2demo works for development/testing. For production use, register for a free key at https://www.europeana.eu/en/account/api-keys.
https://api.europeana.eu/record/v2/search.json?query=vermeer&wskey=api2demo
Fields are prefixed with dc (Dublin Core) or edm (Europeana Data Model):
title — array of title stringsdcCreator — creator namesdcDescription — descriptionsyear — year(s) as stringscountry — country of holding institutiondataProvider — institution name (e.g., "Rijksmuseum")rights — license URLedmPreview — thumbnail URLedmIsShownAt — link to item on provider's sitetype — IMAGE, TEXT, SOUND, VIDEO, 3Dreusability=open?query=vermeer&reusability=open
Returns only items with open licenses (Public Domain, CC0, CC BY, CC BY-SA).
LangAware suffixdcTitleLangAware contains titles keyed by language code:
{"en": ["The Milkmaid"], "nl": ["Het melkmeisje"]}
| Param | Description | Example |
|-------|-------------|---------|
| query | Search query (Lucene syntax) | query=vermeer |
| qf | Query filter (field:value) | qf=TYPE:IMAGE |
| reusability | License filter: open, restricted, permission | reusability=open |
| media | Has media (true/false) | media=true |
| rows | Results per page (max 100) | rows=20 |
| start | Result offset (1-based) | start=21 |
| sort | Sort field | sort=score+desc |
| wskey | API key (required) | wskey=api2demo |
| profile | Response detail: minimal, standard, rich | profile=rich |
qf=)| Filter | Values |
|--------|--------|
| TYPE | IMAGE, TEXT, SOUND, VIDEO, 3D |
| COUNTRY | Country name (e.g., Netherlands) |
| LANGUAGE | ISO code (e.g., en, nl, de) |
| PROVIDER | Provider name |
| DATA_PROVIDER | Institution name |
| RIGHTS | License URL |
| what | Subject/keyword |
| where | Place |
| when | Time period |
Multiple filters: repeat qf= parameter.
https://api.europeana.eu/record/v2/{RECORD_ID}.json?wskey=api2demo
Record IDs look like /15502/GG_9128 (from the id field in search results).
{
"success": true,
"totalResults": 1573,
"items": [
{
"id": "/90402/SK_A_2344",
"title": ["The Milkmaid", "Het melkmeisje"],
"dcCreator": ["Johannes Vermeer"],
"year": ["1660"],
"country": ["Netherlands"],
"dataProvider": ["Rijksmuseum"],
"type": "IMAGE",
"rights": ["http://creativecommons.org/publicdomain/mark/1.0/"],
"edmPreview": ["https://api.europeana.eu/thumbnail/v2/..."],
"edmIsShownAt": ["http://hdl.handle.net/..."],
"edmIsShownBy": ["https://lh3.googleusercontent.com/..."],
"score": 20.9
}
]
}
from scripts.europeana_api import EuropeanaAPI
eu = EuropeanaAPI() # uses api2demo key by default
# Basic search
results = eu.search("vermeer")
# Filtered search
results = eu.search("medieval manuscript", type="TEXT", country="France", reusability="open")
# Get single record
record = eu.get_record("/15502/GG_9128")
# Summarize
for r in results:
print(eu.summarize(r))
api2demo for testing onlyreferences/api_reference.md — Complete query filter and response field referencescripts/europeana_api.py — Python client with search, record lookup, and open-access filteringdevelopment
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".