Skip to content

Search the Pleiades gazetteer from Python over-the-web. Get JSON results.

License

Notifications You must be signed in to change notification settings

isawnyu/pleiades_search_api

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

36 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Pleiades Search API

Search Pleiades from Python over-the-web. Get JSON results.

The pleiades_search_api package is written and maintained by Tom Elliott for the Institute for the Study of the Ancient World.
© Copyright 2022-2024 by New York University
Licensed under the AGPL-3.0; see LICENSE.txt file.

Getting started

Use a python 3.6 or greater environment and then run pip install -U -e .. Fire up the python interpreter and:

>>> from pleiades_search_api.search import Query, SearchInterface

# define a simple title query
>>> q = Query()
>>> q.supported
['bbox', 'description', 'feature_type', 'tag', 'text', 'title']
q.set_parameter("title", "Zucchabar")

# initialize the search interface 
>>> si = SearchInterface()
Using default HTTP Request header for User-Agent = "pleiades_search_api/0.0.1 (+https://github.com/isawnyu/pleiades_search_api)". We strongly prefer you define your own unique user-agent string.
# set a custom user-agent string: https://en.wikipedia.org/wiki/User_agent#Format_for_automated_agents_(bots)
>>> ua = "pleiades_search_api_demo/0.1 (+https://github.com/isawnyu/pleiades_search_api)"
>>> si = SearchInterface(user_agent=ua)

# run the search and explore the results
>>> results = si.search(q)
>>> results.keys()
dict_keys(['query', 'hits'])
>>> from pprint import pprint
>>> pprint(results["hits"], indent=4)
[   {   'id': '295374',
        'summary': 'Zucchabar was an ancient city of Mauretania Caesariensis '
                   'with Punic origins. The modern Algerian community of '
                   'Miliana lies atop and around the largely unexcavated '
                   'ancient site. Epigraphic evidence indicates that the Roman '
                   'emperor Augustus established a veteran colony there.',
        'title': 'Zucchabar',
        'uri': 'https://pleiades.stoa.org/places/295374'}]

# try a more complicated search
>>> q.clear_parameters()
>>> q.set_parameter("text", ["Punic", "Phoenician"], "OR")
>>> results = si.search(q)
>>> len(results["hits"])
100 
# the API sets a 100 hits limit, so try narrowing the search geospatially
>>> q.set_parameter("bbox", (-4.0,33.0,2.0,40.0))
>>> results = si.search(q)
>>> len(results["hits"])
4
>>> pprint(results["hits"], indent=4)
[   {   'id': '482947334',
        'summary': 'A Phoenician settlement of the eighth and seventh '
                   'centuries B.C.',
        'title': 'Sa Caleta',
        'uri': 'https://pleiades.stoa.org/places/482947334'},
    {   'id': '266038',
        'summary': 'Sexi/Saxetanum (modern Almuñécar) was a Phoenician colony '
                   'established ca. 800 BC that eventually became a Roman one '
                   '(Sexi Firmum Iulium).',
        'title': 'Sexi/Saxetanum',
        'uri': 'https://pleiades.stoa.org/places/266038'},
    {   'id': '265954',
        'summary': 'Lucentum was a Phoenician and then Roman settlement in '
                   'Tarraconensis that was largely abandoned after the third '
                   'century.',
        'title': 'Lucentum',
        'uri': 'https://pleiades.stoa.org/places/265954'},
    {   'id': '265849',
        'summary': 'Carthago Nova/Col. Urbs Iulia (modern Cartagena, Spain) '
                   'was originally an indigenous settlement that was '
                   'subsequently refounded first as a Punic site Qart Hadasht '
                   '("New City") in 228 BC and later as a Roman city.',
        'title': 'Carthago Nova/Col. Urbs Iulia',
        'uri': 'https://pleiades.stoa.org/places/265849'}]

# you can retrieve the complete JSON representation of any search result
>>> juri = results["hits"][3]["uri"] + "/json"
>>> p = si.web.get(juri)
>>> type(p)
<class 'requests.models.Response'>
>>> print(p.json().keys())
dict_keys(['features', 'contributors', 'locations', 'connections', 'references', 'names', 'id', 'subject', 'title', 'provenance', 'placeTypeURIs', 'details', '@context', 'review_state', 'type', 'description', 'reprPoint', 'placeTypes', 'bbox', 'connectsWith', 'rights', 'created', 'uri', 'creators', '@type', 'history'])
>>> p.json()["reprPoint"]
[-0.9879534999999999, 37.602787]
>>> geometries = [loc["geometry"] for loc in p.json()["locations"]]
>>> for g in geometries:
...     f"{g['type']}({','.join([str(c) for c in g['coordinates']])})"
... 
'Point(-0.991387,37.605678)'
'Point(-0.98452,37.599896)'

# note that using the si.web.get method caches responses locally
>>> p.from_cache
False
>>> p = si.web.get(juri)
>>> p.from_cache
True
# cache-related response headers are used by requests-cache
>>> p.headers["expires"]
'Sun, 11 Mar 2012 22:14:49 GMT'

About

Search the Pleiades gazetteer from Python over-the-web. Get JSON results.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages