Skip to main content

Tools for converting, merging, persisting and reading RDF data in different formats.

Project description

rdfx

A small Python utility to convert, merge, and read/persist RDF data in different formats, across different "persistence systems".

How to Use

The command line utility covers merge and conversion functionality, and simplifies certain aspects of this. The

Python

Run the rdfx.py script with Python having installed the packages required by requirements.txt.

BASH (Linux, Mac etc)

To utilise the command line util run: python rdfx.py *args

To convert a file: python rdfx.py convert myfile.ttl -f nt -o output_dir For multiple files: python rdfx.py convert myfile1.ttl myfile2.ttl -f nt -o output_dir A directory of files: python rdfx.py convert files_dir -f nt -o output_dir To merge multiple files: python rdfx.py merge myfile1.ttl myfile2.ttl -f nt -o output_dir To merge a directory of files: python rdfx.py merge files_dir -f nt -o output_dir To remove sort and remove unused prefixes in a turtle file: python rdfx.py clean myfile.ttl

To simplify usage of the command line utility at present, the following behaviour has been set:

Type Output Filenames
Merge merged.{format}
Convert file1.{format} file2.{format} ...

That is, when merging, the output filename will be "merged", with the correct file format. When converting, the output filename will be the same as the input filename, with the correct file format. This behaviour simplifies input to the command line util, allowing multiple files and directories to be input without confusion as to which specified filenames are for input or output, and mappings between input and output, especially directories or multiple files are converted/merged.

The python utilities behind the command line tool can be configured to set user specified filenames, for these cases use Python.

SOP / EDG usage

The SOP persistence system can be used to read and write to/from EDG master graphs and workflows. The SOP persistence system can be instantiated with the following optional parameters:

  1. location, defaults to "http://localhost:8083"
  2. username, defaults to "Administrator"
  3. password, defaults to ""
  4. timeout, defaults to 60 seconds Example instantiation with defaults:
from rdfx.persistence_systems import SOP
local_sop_ps = SOP()

The following methods are available on instances of the SOP class:

Method Paramters Returns
read graph URN
rdf_format
list of comments
RDFLib Graph
write RDFLib Graph
graph IRI
list of comments (optional)
The IRI of the created graph
query query
graph_iri
return_format
The query results
asset_collection_size asset_iri Triples count for the given asset
create_datagraph datagraph_name (optional)
description (optional)
subjectArea (optional)
default_namespace (optional)
HTTP headers (optional)
datagraph IRI
create_workflow graph_iri
workflow_name (optional)
HTTP headers (optional)
workflow IRI
create_manifest manifest_name (optional)
description (optional)
subjectArea (optional)
default_namespace (optional)
HTTP headers (optional)
the IRI for the manifest
asset_exists graph_name true/false

Command line tool documentation

These usage notes come from running the help command in the tool, e.g. python rdfx.ph -h:

usage: rdfx.py [-h] [--format {ttl,turtle,json,json-ld,jsonld,owl,xml,rdf,nt,n3}] [-o OUTPUT] [--comments COMMENTS] {convert,merge} data [data ...]

positional arguments:
  {convert,merge}
  data                  Path to the RDF file or directory of files for merging or conversion.

optional arguments:
  -h, --help            show this help message and exit
  --format {ttl,turtle,json,json-ld,jsonld,owl,xml,rdf,nt,n3}, -f {ttl,turtle,json,json-ld,jsonld,owl,xml,rdf,nt,n3}
                        The RDFlib token for the RDF format you want to convert the RDF file to.
  -o OUTPUT, --output OUTPUT
                        if set, the output location for merged or converted files, defaults to the current working directory
  --comments COMMENTS   Comments to prepend to the RDF, turtle only.

License

LGPL - see the LICENSE file for details

Dependencies

This uses RDFlib.

Contact

Original library: Nicholas J. Car Data Systems Architect SURROUND Australia Pty Ltd nicholas.car@surroundaustralia.com GitHub: nicholascar ORCID: https://orcid.org/0000-0002-8742-7730

Updates around persistence systems: David Habgood Application Architect SURROUND Australia Pty Ltd david.habgood@surroundaustrlaia.com GitHub: nicholascar https://orcid.org/0000-0002-3322-1868

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

rdfx-0.4.18.tar.gz (160.2 kB view details)

Uploaded Source

Built Distribution

rdfx-0.4.18-py3-none-any.whl (160.4 kB view details)

Uploaded Python 3

File details

Details for the file rdfx-0.4.18.tar.gz.

File metadata

  • Download URL: rdfx-0.4.18.tar.gz
  • Upload date:
  • Size: 160.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.7

File hashes

Hashes for rdfx-0.4.18.tar.gz
Algorithm Hash digest
SHA256 1c624b79f9aa83c7f4fe92de7359820f6c0420dd56ce8cb8ab0f1e0dbf76109c
MD5 81e0bddf72c13c72378607cba37a5c43
BLAKE2b-256 ff35a2c0a426eabb4eb2fc07b0101905b814b5af2795a6f42a25b66d8a5eef57

See more details on using hashes here.

File details

Details for the file rdfx-0.4.18-py3-none-any.whl.

File metadata

  • Download URL: rdfx-0.4.18-py3-none-any.whl
  • Upload date:
  • Size: 160.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.7

File hashes

Hashes for rdfx-0.4.18-py3-none-any.whl
Algorithm Hash digest
SHA256 8fa5fe18da4de7a320a8df042cc22f06b2101f907ff566b31e63495662d10a45
MD5 6ec47018b75dd4f72f0fd9ca3e713f56
BLAKE2b-256 588ef6c5a555e2938390a0c0821fad2fdd4db594f3578e12a0494997c5511e4b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page