Skip to main content

A Python package of RDF data manipulation functions that can be called from the command line or other software

Project description

Kurra

A Python package of RDF data manipulation and data management functions that can be called from the command line or other software.

This library uses the RDFLib under-the-hood to process RDF data. It supplies functions to:

  • manipulate local RDF files
  • send commands to RDF databases "triplestores"
  • SPARQL query files or databases
  • SHACL validate or apply rules to RDF data

kurra is for convenience: the functions it provides are simple but kurra saves you having to reinvent wheels.

CLI app

kurra presents a Command Line Interface that can be used on Mac, Linux and Windows (WSL) command prompts.

Once you have installed kurra (see below), you can ask it to tell you what commands it supports by using the --help or just -h, command, e.g.:

kurra -h

which will return something like:

╭─ Options ─────────────────────────────────────────────────────────────────────────────────╮
│ --version             -v                                                                  │
│ --help                -h        Show this message and exit.                               │
╰───────────────────────────────────────────────────────────────────────────────────────────╯
╭─ Commands ────────────────────────────────────────────────────────────────────────────────╮
│ db       RDF database commands                                                            │
│ file     RDF file commands                                                                │
│ shacl    SHACL commands                                                                   │
│ sparql   SPARQL queries to local RDF files or a database                                  │
╰───────────────────────────────────────────────────────────────────────────────────────────╯

To find out more about the specific options within db, file, shacl & sparql, run the help command at the next level, like this:

kurra db -h

or

kurra file -h

etc. for shacl & sparql

To get further help for the particular commands. For db, you will see something like this:

 Usage: kurra db [OPTIONS] COMMAND [ARGS]...
                                
 RDF database commands
 
╭─ Options ─────────────────────────────────────────────────────────────────────╮
│ --help  -h        Show this message and exit.                                 │
╰───────────────────────────────────────────────────────────────────────────────╯
╭─ Commands ────────────────────────────────────────────────────────────────────╮
│ sparql   SPARQL query an RDF database                                         │
│ fuseki   Fuseki database commands                                             │
│ gsp      Graph Store Protocol commands                                        │
│ olis     Olis commands                                                        │
╰───────────────────────────────────────────────────────────────────────────────╯

Installation

CLI App

The recommended way to manage and run Python CLI apps is to use the Python package uv which you will need to install first, see the uv installation instructions. then:

uv tool install kurra

Now you can invoke kurra anywhere in your terminal as long as ~/.local/bin is in your PATH.

See the uv documentation on installing tools for more information.

Library

You can also install kurra as a Python library for used of its functions in other applications

pip install kurra

Use the relevant command to add dependencies to your project if you are using a tool like uv, poetry, or conda.

Then import it and use in your code, e.g. for the format functions:

from kurra.file import reformat, make_dataset, export_quads

Development

Install the Poetry project and its dependencies:

task install

Format code:

task format

Test:

task test

You can test the command like app while in development with:

uv tool kurra {COMMANDS}

With {COMMANDS} as per the usual kurra CLI.

Releasing

To build a new release:

  • format code: task format
  • pass tests: task test
  • update version in pyproject.toml
  • Git commit & push all updates
  • Git tag with release version
    • git tag 2.2.4
    • git push --tags
  • make GitHub release
    • this will trigger pypi.yml workflow to publish to PyPI
  • update version in pyproject.toml to next release alpha and push
    • with message 2.2.4 post release

License

BSD-3-Clause license. See LICENSE.

Contact & Support

kurra is maintained by:

KurrawongAI
http://kurrawong.ai
info@kurrawong.ai

Please contact them for all use & support issues.

You can also log issues at the kurra issue tracker:

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

kurra-2.3.1.tar.gz (105.6 kB view details)

Uploaded Source

Built Distribution

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

kurra-2.3.1-py3-none-any.whl (33.9 kB view details)

Uploaded Python 3

File details

Details for the file kurra-2.3.1.tar.gz.

File metadata

  • Download URL: kurra-2.3.1.tar.gz
  • Upload date:
  • Size: 105.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for kurra-2.3.1.tar.gz
Algorithm Hash digest
SHA256 a6f99a2d47266457863f6d133281fbcf99b31576d043f79d2f57080668874e2b
MD5 0477d526786236642fa6c68463ebc6fc
BLAKE2b-256 d7cff1bdc485824b4a3949f75ff7df71352bde6f4a8847d503918e3f49c4250f

See more details on using hashes here.

Provenance

The following attestation bundles were made for kurra-2.3.1.tar.gz:

Publisher: pypi.yml on Kurrawong/kurra

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file kurra-2.3.1-py3-none-any.whl.

File metadata

  • Download URL: kurra-2.3.1-py3-none-any.whl
  • Upload date:
  • Size: 33.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for kurra-2.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 246b0e01db77cdf119de55c4ff6df5e2472f177a446e23de92e223aa6c666ef3
MD5 05c7ba1d1cfcd1e63fc657d633bd865b
BLAKE2b-256 f65855466b4bad44b72bfe381920d73d1a7d73ddeb445f31c3f337eda9f4a7b0

See more details on using hashes here.

Provenance

The following attestation bundles were made for kurra-2.3.1-py3-none-any.whl:

Publisher: pypi.yml on Kurrawong/kurra

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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