Skip to main content

Python library for interacting with the TIND DA API

Project description

python-tind-client

Python library for interacting with the TIND DA API.

Requirements

  • Python 3.12+

Installation

pip install python-tind-client

Install with optional development dependencies:

pip install "python-tind-client[dev]"    # test + lint + debug
pip install "python-tind-client[test]"   # pytest + requests-mock
pip install "python-tind-client[lint]"   # mypy + pydoclint + pylint
pip install "python-tind-client[debug]"  # debugpy

Configuration

Create a TINDClient with optional configuration values:

  • api_key (optional): Your TIND API token. Falls back to the TIND_API_KEY environment variable.
  • api_url (optional): Base URL of the TIND instance (e.g. https://tind.example.edu). Falls back to the TIND_API_URL environment variable.
  • default_storage_dir (optional): Default output directory for downloaded files. Defaults to ./tmp.

Usage

TIND Credentials / Optional ENV config

You will need to either pass your TIND API credentials as arguments when instantiating a TINDClient or set them as environment variables with the following names:

  • TIND_API_KEY
  • TIND_API_URL

instantiate a client

from tind_client import TINDClient

client = TINDClient(
	api_key="your-token",
	api_url="https://tind.example.edu",
	default_storage_dir="/tmp",
)

Fetch pyMARC metadata for a record

record = client.fetch_metadata("116262")
print(record["245"]["a"])  # title

Fetch file metadata for a record

metadata = client.fetch_file_metadata("116262")
print(metadata[0])         # first file metadata dict
print(metadata[0]["url"])  # file download URL

Download a file

# use metadata from previous example
path_to_download = client.fetch_file(metadata[0]["url"])

Search for records

# return a list of record IDs matching a query
ids = client.fetch_ids_search("collection:'Disabled Students Program Photos'")

# return PyMARC records matching a query
records = client.fetch_search_metadata("collection:'Disabled Students Program Photos'")

# return raw XML or PyMARC records from a paginated search
# NOTE: for large result sets, use the write_search_results_to_file() method and then parse that file
xml_results = client.search("collection:'Disabled Students Program Photos'", result_format="xml")
pymarc_results = client.search("collection:'Disabled Students Program Photos'", result_format="pymarc")

# search Tind with a query and write results to an XML file in the default storage directory
records_written = client.write_search_results_to_file("Old Emperor Norton", "full_norton_results.xml")

Running tests

pytest

License

MIT — © 2026 The Regents of the University of California

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

python_tind_client-0.2.1-py3-none-any.whl (9.7 kB view details)

Uploaded Python 3

File details

Details for the file python_tind_client-0.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for python_tind_client-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 1b66c2fc43779da379862ec15969b7ec8937671735d3267f31fc9bffd886e8e3
MD5 c33cf764d33296d712aa957ba67c96d9
BLAKE2b-256 e69ec99a5e8152672e8e0757f5f0d8a37f32060cee01ae0d7ff6daa7983ddb78

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