A small Python library for mapping a concept collection to the skos-ap-no specification.
% pip install -i concepttordf
To create a SKOS-AP-NO concept collection:
from concepttordf.collection import Collection
from concepttordf.concept import Concept
from concepttordf.definition import Definition
# Create collection object
collection = Collection()
collection.identifier = "http://example.com/collections/1"
collection.name = {"en": "A concept collection"}
collection.name = {"nb": "En begrepssamling"}
collection.publisher = "https://example.com/publishers/1"
# Create a concept:
c = Concept()
c.identifier = "http://example.com/concepts/1"
c.term = {"name": {"nb": "inntekt", "en": "income"}}
definition = Definition()
definition.text = {"nb": "ting man skulle hatt mer av",
"en": "something you want more of"}
c.definition = definition
# Add concept to collection:
collection.members.append(c)
# get rdf representation in turtle (default)
rdf = collection.to_rdf()
print(rdf.decode())
Will print the concept according to the specification:
@prefix dcat: <http://www.w3.org/ns/dcat#> .
@prefix dct: <http://purl.org/dc/terms/> .
@prefix ns1: <http://difi.no/skosno#> .
@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> .
@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#> .
@prefix skos: <http://www.w3.org/2004/02/skos/core#> .
@prefix skosno: <http://difi.no/skosno> .
@prefix skosxl: <http://www.w3.org/2008/05/skos-xl#> .
@prefix vcard: <http://www.w3.org/2006/vcard/ns#> .
@prefix xml: <http://www.w3.org/XML/1998/namespace> .
@prefix xsd: <http://www.w3.org/2001/XMLSchema#> .
<http://example.com/collections/1> a skos:Collection ;
rdfs:label "En begrepssamling"@nb ;
dct:publisher <https://example.com/publishers/1> ;
skos:member <http://example.com/concepts/1> .
<http://example.com/concepts/1> a skos:Concept ;
ns1:betydningsbeskrivelse [ a ns1:Definisjon ;
rdfs:label "something you want more of"@en,
"ting man skulle hatt mer av"@nb ] ;
skosxl:prefLabel [ a skosxl:Label ;
skosxl:literalForm "income"@en,
"inntekt"@nb ] .
- python3
- pipenv
% git clone https://github.com/Informasjonsforvaltning/concepttordf.git
% cd concepttordf
% pipenv install
% pipenv shell
% pipenv install --dev -e .
% pytest -rA
With simple coverage-report in output:
% pytest -rA --cov-report term-missing --cov=concepttordf tests/
Wit coverage-report to html:
% pytest -rA --cov-report html --cov=concepttordf tests/
You can enter into Pdb by passing --pdb
to pytest:
pytest --pdb -rA --cov-report term-missing --cov=concepttordf tests/
You can set breakpoints directly in code by using the function breakpoint()
.