Skip to main content

query data exports from the SLUB catalog

Project description

With slubfind you can query data exports from the SLUB catalog in Python.

This package is based on txpyfind, which enables access to data exports from TYPO3-find.

Installation

… via PyPI

pip install slubfind

… or from GitHub source

pip install git+https://github.com/slub/slubfind.git

Command-Line Usage

After installation, the slubfind command is available (also via python -m slubfind). The base URL defaults to https://katalog.slub-dresden.de.

Query

Execute a search query in app format:

slubfind query "manfred bonitz"

With a facet filter and pagination:

slubfind query "python" --facet "format_de14=Book, E-Book" --page 1 --count 10

Document

Fetch a single document by ID in app format:

slubfind document "0-1132486122"

Scroll

Fetch all results for a query:

slubfind scroll "manfred bonitz" --batch 10

Stream results as JSONL (one JSON object per line), useful for piping:

slubfind scroll "manfred bonitz" --stream | jq .id

Settings

Show TYPO3-find settings:

slubfind settings

Solr Parameters

Show Solr parameters for a query:

slubfind solr-params "manfred bonitz"

Solr Request

Show Solr request URL for a query:

slubfind solr-request "manfred bonitz"

From URL

Use --from-url to query using a SLUB catalog URL instead of individual parameters. This works with query, scroll, solr-params, and solr-request:

slubfind query --from-url "https://katalog.slub-dresden.de/?tx_find_find%5Bq%5D%5Bdefault%5D=manfred+bonitz"
slubfind solr-params --from-url "https://katalog.slub-dresden.de/?tx_find_find%5Bq%5D%5Bdefault%5D=manfred+bonitz"

Show Request URL

Use --show-url to print the request URL instead of fetching the response. This works with all subcommands:

slubfind --show-url query "python" --facet "format_de14=Book, E-Book"
slubfind --show-url document "0-1132486122"
slubfind --show-url scroll "python" --batch 10

Export Format

Use --export-format to select the output format. The default is app.

Fetch a document in JSON-LD format:

slubfind document "0-1132486122" --export-format json-ld

Search in JSON-LD format:

slubfind query "manfred bonitz" --export-format json-ld

Environment Variable

Set SLUBFIND_URL to override the default base URL:

export SLUBFIND_URL=https://katalog.slub-dresden.de
slubfind query "manfred bonitz"

Python Usage Example

from slubfind.client import SlubFind
# create SlubFind instance
slub_find = SlubFind()
# retrieve JSON data (query view, app format)
slub_q = slub_find.app_search("manfred bonitz")
# retrieve JSON data (detail view, app format)
slub_doc = slub_find.app_document("0-1132486122")
# retrieve JSON-LD data (detail view)
slub_jsonld = slub_find.jsonld_document("0-1132486122")
# retrieve JSON-LD data (query view)
slub_jsonld_q = slub_find.jsonld_search("manfred bonitz")

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

slubfind-1.9.0.tar.gz (28.5 kB view details)

Uploaded Source

Built Distribution

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

slubfind-1.9.0-py3-none-any.whl (21.9 kB view details)

Uploaded Python 3

File details

Details for the file slubfind-1.9.0.tar.gz.

File metadata

  • Download URL: slubfind-1.9.0.tar.gz
  • Upload date:
  • Size: 28.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for slubfind-1.9.0.tar.gz
Algorithm Hash digest
SHA256 e818d7eefb749927c533c9ce0650d9de32ddd1b8464c9f4d672deec6a24c6cc2
MD5 393b8e2bbefec0f50c3bf9b0f50abf19
BLAKE2b-256 13675f81ddcea101c9ec12e98faf566dea285b789aae777f90374d0eaf64e7a0

See more details on using hashes here.

File details

Details for the file slubfind-1.9.0-py3-none-any.whl.

File metadata

  • Download URL: slubfind-1.9.0-py3-none-any.whl
  • Upload date:
  • Size: 21.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for slubfind-1.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 96e9ab875ce36e454b8250cf6793fbd58e4f67795d539ea2d038a10a5a2c6081
MD5 bfa49b81c13d5d836e7f477c8815c9dc
BLAKE2b-256 5187dcc08dccdc304891dbdd798d1e509c52abad3c65c2dc4dcae937e6b3af14

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