Science Score: 67.0%
This score indicates how likely this project is to be science-related based on various indicators:
-
✓CITATION.cff file
Found CITATION.cff file -
✓codemeta.json file
Found codemeta.json file -
✓.zenodo.json file
Found .zenodo.json file -
✓DOI references
Found 3 DOI reference(s) in README -
✓Academic publication links
Links to: zenodo.org -
○Academic email domains
-
○Institutional organization owner
-
○JOSS paper metadata
-
○Scientific vocabulary similarity
Low similarity (12.8%) to scientific vocabulary
Repository
Basic Info
- Host: GitHub
- Owner: jdehotin
- License: bsd-3-clause
- Language: Python
- Default Branch: main
- Size: 30.2 MB
Statistics
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 12
- Releases: 0
Metadata Files
README.md
RDFLib
RDFLib is a pure Python package for working with RDF. RDFLib contains most things you need to work with RDF, including:
- parsers and serializers for RDF/XML, N3, NTriples, N-Quads, Turtle, TriX, Trig and JSON-LD
- a Graph interface which can be backed by any one of a number of Store implementations
- store implementations for in-memory, persistent on disk (Berkeley DB) and remote SPARQL endpoints
- a SPARQL 1.1 implementation - supporting SPARQL 1.1 Queries and Update statements
- SPARQL function extension mechanisms
RDFlib Family of packages
The RDFlib community maintains many RDF-related Python code repositories with different purposes. For example:
- rdflib - the RDFLib core
- sparqlwrapper - a simple Python wrapper around a SPARQL service to remotely execute your queries
- pyLODE - An OWL ontology documentation tool using Python and templating, based on LODE.
- pyrdfa3 - RDFa 1.1 distiller/parser library: can extract RDFa 1.1/1.0 from (X)HTML, SVG, or XML in general.
- pymicrodata - A module to extract RDF from an HTML5 page annotated with microdata.
- pySHACL - A pure Python module which allows for the validation of RDF graphs against SHACL graphs.
- OWL-RL - A simple implementation of the OWL2 RL Profile which expands the graph with all possible triples that OWL RL defines.
Please see the list for all packages/repositories here:
Help with maintenance of all of the RDFLib family of packages is always welcome and appreciated.
Versions & Releases
7.1.0a0currentmainbranch.7.x.ycurrent release, supports Python 3.8.1+ only.- see Releases
6.x.ysupports Python 3.7+ only. Many improvements over 5.0.0- see Releases
5.x.ysupports Python 2.7 and 3.4+ and is mostly backwards compatible with 4.2.2.
See https://rdflib.dev for the release overview.
Documentation
See https://rdflib.readthedocs.io for our documentation built from the code. Note that there are latest, stable 5.0.0 and 4.2.2 documentation versions, matching releases.
Installation
The stable release of RDFLib may be installed with Python's package management tool pip:
$ pip install rdflib
Some features of RDFLib require optional dependencies which may be installed using pip extras:
$ pip install rdflib[berkeleydb,networkx,html,lxml]
Alternatively manually download the package from the Python Package Index (PyPI) at https://pypi.python.org/pypi/rdflib
The current version of RDFLib is 7.0.0, see the CHANGELOG.md file for what's new in this release.
Installation of the current main branch (for developers)
With pip you can also install rdflib from the git repository with one of the following options:
$ pip install git+https://github.com/rdflib/rdflib@main
or
$ pip install -e git+https://github.com/rdflib/rdflib@main#egg=rdflib
or from your locally cloned repository you can install it with one of the following options:
$ poetry install # installs into a poetry-managed venv
or
$ pip install -e .
Getting Started
RDFLib aims to be a pythonic RDF API. RDFLib's main data object is a Graph which is a Python collection
of RDF Subject, Predicate, Object Triples:
To create graph and load it with RDF data from DBPedia then print the results:
```python from rdflib import Graph g = Graph() g.parse('http://dbpedia.org/resource/Semantic_Web')
for s, p, o in g: print(s, p, o) ``` The components of the triples are URIs (resources) or Literals (values).
URIs are grouped together by namespace, common namespaces are included in RDFLib:
python
from rdflib.namespace import DC, DCTERMS, DOAP, FOAF, SKOS, OWL, RDF, RDFS, VOID, XMLNS, XSD
You can use them like this:
```python from rdflib import Graph, URIRef, Literal from rdflib.namespace import RDFS, XSD
g = Graph()
semweb = URIRef('http://dbpedia.org/resource/Semantic_Web')
type = g.value(semweb, RDFS.label)
``
WhereRDFSis the RDFS namespace,XSDthe XML Schema Datatypes namespace andg.value` returns an object of the triple-pattern given (or an arbitrary one if multiple exist).
Or like this, adding a triple to a graph g:
python
g.add((
URIRef("http://example.com/person/nick"),
FOAF.givenName,
Literal("Nick", datatype=XSD.string)
))
The triple (in n-triples notation) <http://example.com/person/nick> <http://xmlns.com/foaf/0.1/givenName> "Nick"^^<http://www.w3.org/2001/XMLSchema#string> .
is created where the property FOAF.givenName is the URI <http://xmlns.com/foaf/0.1/givenName> and XSD.string is the
URI <http://www.w3.org/2001/XMLSchema#string>.
You can bind namespaces to prefixes to shorten the URIs for RDF/XML, Turtle, N3, TriG, TriX & JSON-LD serializations:
python
g.bind("foaf", FOAF)
g.bind("xsd", XSD)
This will allow the n-triples triple above to be serialised like this:
python
print(g.serialize(format="turtle"))
With these results: ```turtle PREFIX foaf: http://xmlns.com/foaf/0.1/ PREFIX xsd: http://www.w3.org/2001/XMLSchema#
http://example.com/person/nick foaf:givenName "Nick"^^xsd:string . ```
New Namespaces can also be defined:
```python dbpedia = Namespace('http://dbpedia.org/ontology/')
abstracts = list(x for x in g.objects(semweb, dbpedia['abstract']) if x.language=='en') ```
See also ./examples
Features
The library contains parsers and serializers for RDF/XML, N3, NTriples, N-Quads, Turtle, TriX, JSON-LD, RDFa and Microdata.
The library presents a Graph interface which can be backed by any one of a number of Store implementations.
This core RDFLib package includes store implementations for in-memory storage and persistent storage on top of the Berkeley DB.
A SPARQL 1.1 implementation is included - supporting SPARQL 1.1 Queries and Update statements.
RDFLib is open source and is maintained on GitHub. RDFLib releases, current and previous are listed on PyPI
Multiple other projects are contained within the RDFlib "family", see https://github.com/RDFLib/.
Running tests
Running the tests on the host
Run the test suite with pytest.
shell
poetry install
poetry run pytest
Running test coverage on the host with coverage report
Run the test suite and generate a HTML coverage report with pytest and pytest-cov.
shell
poetry run pytest --cov
Viewing test coverage
Once tests have produced HTML output of the coverage report, view it by running:
shell
poetry run pytest --cov --cov-report term --cov-report html
python -m http.server --directory=htmlcov
Contributing
RDFLib survives and grows via user contributions! Please read our contributing guide and developers guide to get started. Please consider lodging Pull Requests here:
To get a development environment consider using Gitpod or Google Cloud Shell.
You can also raise issues here:
Support & Contacts
For general "how do I..." queries, please use https://stackoverflow.com and tag your question with rdflib.
Existing questions:
If you want to contact the rdflib maintainers, please do so via:
- the rdflib-dev mailing list: https://groups.google.com/group/rdflib-dev
- the chat, which is available at gitter or via matrix #RDFLib_rdflib:gitter.im
Owner
- Login: jdehotin
- Kind: user
- Repositories: 4
- Profile: https://github.com/jdehotin
Citation (CITATION.cff)
cff-version: 1.2.0 message: "If you use this software, please cite it as below." authors: - family-names: "Krech" given-names: "Daniel" - family-names: "Grimnes" given-names: "Gunnar AAstrand" - family-names: "Higgins" given-names: "Graham" - family-names: "Hees" given-names: "Jörn" orcid: "https://orcid.org/0000-0002-0084-8998" - family-names: "Aucamp" given-names: "Iwan" orcid: "https://orcid.org/0000-0002-7325-3231" - family-names: "Lindström" given-names: "Niklas" - family-names: "Arndt" given-names: "Natanael" orcid: "https://orcid.org/0000-0002-8130-8677" - family-names: "Sommer" given-names: "Ashley" orcid: "https://orcid.org/0000-0003-0590-0131" - family-names: "Chuc" given-names: "Edmond" orcid: "https://orcid.org/0000-0002-6047-9864" - family-names: "Herman" given-names: "Ivan" orcid: "https://orcid.org/0000-0003-0782-2704" - family-names: "Nelson" given-names: "Alex" - family-names: "McCusker" given-names: "Jamie" orcid: "https://orcid.org/0000-0003-1085-6059" - family-names: "Gillespie" given-names: "Tom" - family-names: "Kluyver" given-names: "Thomas" orcid: "https://orcid.org/0000-0003-4020-6364" - family-names: "Ludwig" given-names: "Florian" - family-names: "Champin" given-names: "Pierre-Antoine" orcid: "https://orcid.org/0000-0001-7046-4474" - family-names: "Watts" given-names: "Mark" - family-names: "Holzer" given-names: "Urs" - family-names: "Summers" given-names: "Ed" - family-names: "Morriss" given-names: "Whit" - family-names: "Winston" given-names: "Donny" - family-names: "Perttula" given-names: "Drew" - family-names: "Kovacevic" given-names: "Filip" orcid: "https://orcid.org/0000-0002-2854-0434" - family-names: "Chateauneu" given-names: "Remi" orcid: "https://orcid.org/0000-0002-7505-8149" - family-names: "Solbrig" given-names: "Harold" orcid: "https://orcid.org/0000-0002-5928-3071" - family-names: "Cogrel" given-names: "Benjamin" orcid: "https://orcid.org/0000-0002-7566-4077" - family-names: "Stuart" given-names: "Veyndan" title: "RDFLib" version: 7.0.0 date-released: 2023-08-02 url: "https://github.com/RDFLib/rdflib" doi: 10.5281/zenodo.6845245
GitHub Events
Total
Last Year
Dependencies
- actions/checkout v4 composite
- arduino/setup-task v2 composite
- docker/login-action v3 composite
- dorny/test-reporter v1 composite
- actions/cache v4 composite
- actions/checkout v4 composite
- actions/setup-java v4 composite
- actions/setup-python v5 composite
- actions/upload-artifact v4 composite
- arduino/setup-task v2 composite
- coverallsapp/github-action master composite
- docker.io/library/python 3.12.2-slim@sha256 build
- docker.io/library/python 3.12.2-slim@sha256 build
- poetry ==1.8.3 development
- html5lib * test
- rdflib ==7.0.0 test
- html5lib ==1.1 test
- isodate ==0.6.1 test
- pyparsing ==3.0.9 test
- rdflib ==7.0.0 test
- six ==1.16.0 test
- webencodings ==0.5.1 test
- alabaster 0.7.13
- babel 2.12.1
- berkeleydb 18.1.8
- black 24.4.0
- certifi 2023.7.22
- charset-normalizer 3.2.0
- click 8.1.7
- colorama 0.4.6
- coverage 7.4.4
- docutils 0.20.1
- exceptiongroup 1.1.3
- html5lib 1.1
- idna 3.4
- imagesize 1.4.1
- importlib-metadata 6.8.0
- iniconfig 2.0.0
- isodate 0.6.1
- jinja2 3.1.2
- lxml 4.9.3
- lxml-stubs 0.5.1
- markdown-it-py 3.0.0
- markupsafe 2.1.3
- mdit-py-plugins 0.4.0
- mdurl 0.1.2
- mypy 1.6.1
- mypy-extensions 1.0.0
- myst-parser 2.0.0
- networkx 3.1
- packaging 23.1
- pathspec 0.11.2
- pbr 5.11.1
- platformdirs 3.10.0
- pluggy 1.3.0
- pygments 2.16.1
- pyparsing 3.1.2
- pytest 7.4.3
- pytest-cov 5.0.0
- pytz 2023.3
- pyyaml 6.0.1
- requests 2.31.0
- ruff 0.4.1
- setuptools 69.5.1
- six 1.16.0
- snowballstemmer 2.2.0
- sphinx 7.1.2
- sphinx-autodoc-typehints 1.25.2
- sphinxcontrib-apidoc 0.5.0
- sphinxcontrib-applehelp 1.0.4
- sphinxcontrib-devhelp 1.0.2
- sphinxcontrib-htmlhelp 2.0.1
- sphinxcontrib-jsmath 1.0.1
- sphinxcontrib-qthelp 1.0.3
- sphinxcontrib-serializinghtml 1.1.5
- tomli 2.0.1
- types-setuptools 69.5.0.20240415
- typing-extensions 4.11.0
- urllib3 2.0.4
- webencodings 0.5.1
- wheel 0.43.0
- zipp 3.16.2
- black 24.4.0 develop
- lxml-stubs >=0.4,<0.6 develop
- mypy ^1.1.0 develop
- myst-parser ^2.0.0 docs
- sphinx ^7.1.1 docs
- sphinx-autodoc-typehints ^1.17.1 docs
- sphinxcontrib-apidoc >=0.3,<0.6 docs
- typing-extensions ^4.5.0 docs
- ruff >=0.0.286,<0.4.2 lint
- berkeleydb ^18.1.0
- html5lib ^1.0
- isodate ^0.6.0
- lxml ^4.3.0
- networkx >=2,<4
- pyparsing >=2.1.0,<4
- python ^3.8.1
- coverage ^7.0.1 tests
- pytest ^7.1.3 tests
- pytest-cov >=4,<6 tests
- setuptools >=68,<70 tests
- types-setuptools >=68.0.0.3,<70.0.0.0 tests
- wheel >=0.42,<0.44 tests