34 releases (21 breaking)
0.22.1 | Nov 21, 2023 |
---|---|
0.21.0 | Oct 18, 2023 |
0.19.0 | Jun 6, 2023 |
0.18.0 | Feb 28, 2023 |
0.2.0-beta | Jul 12, 2020 |
#688 in Data structures
3,049 downloads per month
Used in 15 crates
(2 directly)
155KB
5K
SLoC
Generalized RDF datasets.
The Resource Description Framework (RDF) is a powerful method for modeling data and knowledge defined by the World Wide Web Consortium (W3C). A RDF dataset consists in a collection of graphs connecting nodes, values and predicates. This crate provides traits and implementations of Generalized RDF (gRDF) where nodes, values and predicates have the same representation.
Note that this crates requires rust compiler version 1.65 or later. It needs Generic Associated Typed (GAT) to work properly.
Basic usage
Exploring a dataset
Each Dataset
implementation provides many iterators to explore the data.
One simple way is to iterate through the quad of the dataset:
for Quad(subject, predicate, object, graph) in dataset.quads() {
// do something
}
Another way is to access each graph individually using Dataset::graph
.
For a given graph, it is then possible to iterate through the triples of the
graph:
let graph = dataset.graph(id).unwrap();
for Triple(subject, predicate, object) in graph.triples() {
// do something
}
It is also possible to explore the graph logically, subject by subject, predicate by predicate, object by object:
// for each subject of the graph...
for (subject, predicates) in graph.subjects() {
// for each predicate it is subject...
for (predicate, objects) in predicates {
// for each triple (subject, predicate, object)...
for object in objects {
// do something
}
}
}
Inserting new data
Insertion can be done on MutableDataset
implementations using
MutableDataset::insert
:
let mut dataset: HashDataset<Term> = HashDataset::new();
dataset.insert(Quad(subject, predicate, object, graph));
Again it is possible to access each graph of the dataset mutably:
let mut graph = dataset.graph_mut(id).unwrap();
graph.insert(Triple(subject, predicate, object));
Custom node type
The type used to represent RDF nodes (subjects, predicate and objects) is a
parameter of the dataset. Anything can be used although this crate provide a
default Term
type that represents generic RDF nodes (blank nodes,
IRI-named nodes and literal values).
License
Licensed under either of
- Apache License, Version 2.0 (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
Dependencies
~6.5MB
~136K SLoC