Skip to main content

Python wrapper for RDFRules.

Project description

PyPI - Version PyPI - Python Version

PyRDFRules

RDFRules Documentation VŠE


Table of Contents

PyRDFRules

PyRDFRules is a Python wrapper for the graph rule mining tool RDFRules.

RDFRules

RDFRules is a powerful analytical tool for rule mining from RDF knowledge graphs. It offers a complex rule mining solution including RDF data pre-processing, rules post-processing and prediction abilities from rules. The core of RDFRules is written in the Scala language. Besides the Scala API, RDFRules also provides REST web service with graphical user interface via a web browser.

Repository for RDFRules can be found at propi/rdfrules.

Getting started

PyRDFRules is distributed as a Python library through PyPi. The primary goal of this API is to faciliate the easy use of RDFRules through a Python interface.

Prerequisites

A minimum Python version of 3.12.2 is required. You can check your Python version using python --version.

Installation

pip install pyrdfrules

Usage

Full documentation is available at a dedicated documentation site. Code samples can be found in the sample directory, including a Python notebook.

Currently, using a remote HTTP instance of RDFRules or a local instance of RDFRules is supported. Automatic installation of JVM if not present and of RDFRules is supported, and the library takes care of running the RDFRules application.

Remote instance

To connect to a remote instance of RDFRules, create an application and use the start_remote method.

from pydantic_core import Url

import pyrdfrules.application

app = pyrdfrules.application.Application()

rdfrules = await app.start_remote(
    url = Url("http://YOUR_RDFRULES_INSTANCE/api/")
)

Local instance

todo

As a last step, launch the pipeline, wait for all results and print the head, body and measures of each mined rule.

Run a task

A task is a series of steps (a pipeline) provided to RDFRules. Tasks are used to mine rules, index, cache or otherwise manipulate data...

If you have a JSON task ready, you can execute it in the following way:

from pyrdfrules.common.task.task import Task

task : Task = None

with open("./task.json", "r") as file:        
    task_json_from_file = file.read()
    task = await rdfrules.task.create_task_from_string(task_json_from_file)
    
await rdfrules.task.run_task(task)

This will block execution until the task is finished. You can then access the results of the task once it's done.

Full pipeline sample matching the DBpedia & YAGO example from the RDFRules web instance can be found in sample/dbpedia.py or DOCUMENTATION LINK (todo).

Developing

To initialize your environment:

./init.sh

To run a build and run jupyter lab:

./run.sh

Roadmap

  • Sample interface
  • Implement JSON serialization of pipeline
  • Implement communication with RDFRules

Contributing

If you have a suggestion to improve this project, please fork the repo and create a pull request. If you encounter any issues, please do raise an issue with an appropriate tag. Feature requests, enhancements and bug reports are welcome.

To contribute to this project, first:

  • Fork the Project
  • Create your Feature Branch (git checkout -b feature/AmazingFeature)
  • Commit your Changes (git commit -m 'Add some AmazingFeature')
  • Push to the Branch (git push origin feature/AmazingFeature)
  • Open a Pull Request

License

pyrdfrules is distributed under the terms of the Apache License. See LICENSE for more information.

Acknowledgments

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

pyrdfrules-0.0.2.tar.gz (38.6 kB view details)

Uploaded Source

Built Distribution

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

pyrdfrules-0.0.2-py3-none-any.whl (52.3 kB view details)

Uploaded Python 3

File details

Details for the file pyrdfrules-0.0.2.tar.gz.

File metadata

  • Download URL: pyrdfrules-0.0.2.tar.gz
  • Upload date:
  • Size: 38.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.25.1

File hashes

Hashes for pyrdfrules-0.0.2.tar.gz
Algorithm Hash digest
SHA256 8da1bbb7e8257ed90ff71ed9b37413b491ce3af3fc9dbdb266c63ec94d781631
MD5 d127f81ff8a5e1c9d86c90dec3af1b2b
BLAKE2b-256 18491558e9ff62236081addf2b0152620a20e8a577deedf1c8732bbd77b0a4bb

See more details on using hashes here.

File details

Details for the file pyrdfrules-0.0.2-py3-none-any.whl.

File metadata

  • Download URL: pyrdfrules-0.0.2-py3-none-any.whl
  • Upload date:
  • Size: 52.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.25.1

File hashes

Hashes for pyrdfrules-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 7b72c676b8a77e4d4bb6dc7b88ce38f2900c21f97cc0915e02fa90c1d54f4b71
MD5 421a51335b18a33518f6c99ab97626f9
BLAKE2b-256 d031c5ae20bbfc8379ba1f68b5aa6a474bb0029f5ac548b6cbd1cdbcec16e956

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