|
|
Ligne 1 : |
Ligne 1 : |
- | Les mappings sont édités sur le site http://mappings.dbpedia.org, la documentation en Anglais peut être consultée [http://mappings.dbpedia.org/index.php/How_to_edit_DBpedia_Mappings cette la page]. | + | Les mappings sont édités sur le site http://mappings.dbpedia.org, ce tutoriel présente le fonctionnalités de base des mappings. Une présentation plus complète est donnée dans la page [[Documentation mappings]], la documentation en Anglais peut être consultée [http://mappings.dbpedia.org/index.php/How_to_edit_DBpedia_Mappings cette la page]. |
| | | |
- | Il s'agit d'un mediawiki, différentes données de DBpedia y sont éditées :
| |
- | * l'ontologie
| |
- | ** les classes
| |
- | ** les propriétés
| |
- | ** les datatypes
| |
- | * les mappings pour faire correspondre les modèles à des classes de l'ontologie et leurs attributs à des propriétés.
| |
- |
| |
- | Pour pouvoir éditer le wiki, créer un compte sur le wiki, puis demander les droits d'écriture sur la mailing list ''dbpedia-discussion@lists.sourceforge.net''.
| |
- |
| |
- |
| |
- | == Édition de l'ontologie ==
| |
- |
| |
- | === Édition des classes ===
| |
- |
| |
- | Chaque classes est définie par un modèle [http://mappings.dbpedia.org/index.php/Template:Class <nowiki>{{Class}}</nowiki>] dans la page dans l'espace de noms ''OntologyClass:'' avec le nom de la classe.
| |
- |
| |
- | Par exemple la classe ''http://dbpedia.org/ontology/Person'' est définie dans la page http://mappings.dbpedia.org/index.php/OntologyClass:Person qui contient :
| |
- | <nowiki>{{Class
| |
- | | labels =
| |
- | {{label|en|person}}
| |
- | {{label|de|Person}}
| |
- | {{label|fr|personne}}
| |
- | [...]
| |
- | | rdfs:subClassOf = Agent
| |
- | | owl:equivalentClass = foaf:Person, schema:Person
| |
- | }}</nowiki>
| |
- |
| |
- | Le nom de la classe est donnée par le nom de la page qui contient ce modèle (ici ''Person''), le modèle contient en plus les champs :
| |
- | * ''label'' qui permet de donner les labels dans différentes langues en utilisant le modèle [http://mappings.dbpedia.org/index.php/Template:Label <nowiki>{{label}}</nowiki>]. Ces entrées gênèrent des triplets avec la propriété ''rdfs:label''.
| |
- | * ''comments'' qui permet de donner une explication plus détaillée de la classe dans différentes langues avec les modèles [http://mappings.dbpedia.org/index.php/Template:Comment <nowiki>{{comment}}</nowiki>]. Ces entrées génèrent des triplets avec la propriété ''rdfs:comment''. Une bonne pratique est d'y inclure une référence à un article Wikipédia ou Wiktionnaire.
| |
- | * ''rdfs:subClassOf'', ''owl:equivalentClass'' et ''owl:disjointWith'' pour placer la classe dans la hiérarchie de classes.
| |
- | * ''specificProperties'' permet de spécifier l'unité par défaut à utiliser pour les valeurs d'une propriété applicable à cette classe.
| |
- |
| |
- |
| |
- | ''Liens utiles'':
| |
- | * Hiérarchie de classes existantes : http://mappings.dbpedia.org/server/ontology/classes/
| |
- | * Liste des classes sans label en français : http://mappings.dbpedia.org/server/ontology/labels/missing/fr/
| |
- |
| |
- |
| |
- | === Édition des propriétés ===
| |
- |
| |
- | Chaque propriété est définie dans la page dans l'espace de noms ''OntologyProperty:'' avec le nom de la propriété.
| |
- |
| |
- | Deux modèles sont utilisés suivant s'il s'agit
| |
- | * d'une propriété ayant pour valeur des instances : [http://mappings.dbpedia.org/index.php/Template:ObjectProperty <nowiki>{{ObjectProperty}}</nowiki>],
| |
- | * ou une propriété ayant pour valeur des litéraux : [http://mappings.dbpedia.org/index.php/Template:DatatypeProperty <nowiki>{{DatatypeProperty}}</nowiki>].
| |
- |
| |
- | Les champs de ces modèles sont les mêmes, la seule différence concerne les valeurs admises pour le champ ''rdfs:range''.
| |
- |
| |
- | Par exemple pour propriété ''http://dbpedia.org/ontology/locationCity'' est définie dans la page http://mappings.dbpedia.org/index.php/OntologyProperty:LocationCity qui contient :
| |
- | <nowiki>{{ObjectProperty
| |
- | | labels =
| |
- | {{label|en|location city}}
| |
- | {{label|fr|situé dans la ville}}
| |
- | [...]
| |
- | | rdfs:domain = Organisation
| |
- | | rdfs:range = City
| |
- | | rdfs:subPropertyOf = location
| |
- | |comments =
| |
- | {{comment|en|City the thing is located.}}
| |
- | }}</nowiki>
| |
- | Le champ ''rdfs:range'' doit contenir une classe définie dans le wiki.
| |
- |
| |
- | La propriété ''http://dbpedia.org/ontology/birthDate'' est définie dans la page http://mappings.dbpedia.org/index.php/OntologyProperty:BirthDate qui contient :
| |
- | <nowiki>{{DatatypeProperty
| |
- | | labels =
| |
- | {{label|en|birth date}}
| |
- | {{label|fr|date de naissance}}
| |
- | {{label|de|Geburtsdatum}}
| |
- | [...]
| |
- | | rdfs:domain = Person
| |
- | | rdfs:range = xsd:date
| |
- | | rdf:type = owl:FunctionalProperty
| |
- | | owl:equivalentProperty = schema:birthDate
| |
- | }}</nowiki>
| |
- | Le champ ''rdfs:range'' doit contenir soit un datatype [http://www.w3.org/TR/xmlschema-2/#built-in-datatypes XSD], soit un datatype défini dans le wiki (voir [[#Édition_des_datatypes]]).
| |
- |
| |
- |
| |
- | Les autres champs sont en commun :
| |
- | * ''labels'' et ''comments'', définis comme pour les classes permettent d'exprimer et d'expliquer la propriété dans différentes langues.
| |
- | * ''rdfs:domain'' donne le domaine de la propriété, c'est-à-dire une classe à laquelle doivent appartenir les sujets de la propriété, celle-ci doit avoir été définie dans le wiki.
| |
- | * ''rdfs:subPropertyOf'' et ''owl:equivalentProperty'' permettent de définir des relations de généralisation/spécialisation ou d'équivalence par rapport à d'autres propriétés, celles-ci doivent être définies dans le wiki.
| |
- | * ''rdf:type'' permet de préciser le type de la propriété (au delà du type ''owl:ObjectProperty'' / ''owl:DatatypeProperty''). Actuellement seul le type ''owl:FunctionalProperty'' peut être donné, il signifie que la propriété définit une fonction, c'est-à-dire qu'elle ne peut prendre qu'une valeur par sujet.
| |
- |
| |
- |
| |
- | ''Liens utiles'' :
| |
- | * Liste des propriétés : http://mappings.dbpedia.org/index.php?title=Special:AllPages&namespace=202
| |
- | * Liste des propriétés sans label en français : http://mappings.dbpedia.org/server/ontology/labels/missing/fr/
| |
- |
| |
- |
| |
- |
| |
- | === Édition des datatypes ===
| |
- |
| |
- | Les '''datatypes''' (ou types de données) permettent de définir des types de valeurs absents du vocabulaire [http://www.w3.org/TR/xmlschema-2/#built-in-datatypes XSD], notemment pour définir des unités (centimètre, litre, ...)
| |
- |
| |
- | Chaque type de donnée est définie par un modèle [http://mappings.dbpedia.org/index.php/Template:Datatype <nowiki>{{Datatype}}</nowiki>] dans la page dans l'espace de noms ''Datatype:'' avec le nom du type de donnée.
| |
- |
| |
- | Par exemple la classe ''http://dbpedia.org/ontology/Currency'' est définie dans la page http://mappings.dbpedia.org/index.php/Datatype:Currency qui contient :
| |
- | <nowiki>{{Datatype
| |
- | |labels =
| |
- | {{label|en|Currency}}
| |
- | {{label|fr|Monnaie}}
| |
- | [...]
| |
- | }}</nowiki>
| |
- |
| |
- |
| |
- | Liens utiles :
| |
- | * Liste des datatypes http://mappings.dbpedia.org/index.php?title=Special:AllPages&namespace=206
| |
- | * Liste des datatypes sans label en français : http://mappings.dbpedia.org/server/ontology/labels/missing/fr/
| |
- |
| |
- |
| |
- |
| |
- | == Édition des mappings ==
| |
- |
| |
- | === Principe ===
| |
- |
| |
- | Les modèles (''template'' en anglais), en particulier les infobox sont utilisés pour donner des informations factuelles sur les éléments décrits.
| |
- | Différents modèles sont utilisés suivant le type du sujet décrit (Artiste, Batiment, Évènement ...)
| |
- |
| |
- | Chaque modèle contient une liste d'attributs qui contiennent les valeurs décrivant le sujet.
| |
- | La signification des attributs dépend du modèle, par exemple dans les [http://fr.wikipedia.org/wiki/Modèle:Infobox_Musée Infobox Musée], l'attribut '''pays''' désigne l'emplacement du musée, alors que dans les [http://fr.wikipedia.org/wiki/Modèle:Infobox_Cycliste Infobox Cycliste] il désigne la nationalité sportive du cycliste.
| |
- |
| |
- | Les mappings permettent deux choses :
| |
- | * typer les instances en associant une classe de l'ontologie à chaque modèle
| |
- | * traduire les attributs des modèles en propriétés de l'ontologie.
| |
- |
| |
- |
| |
- | === Mapping élémentaire d'un modèle ===
| |
- |
| |
- | Le mapping d'un modèle de Wikipédia en français est défini par un modèle [http://mappings.dbpedia.org/index.php/Template:TemplateMapping <nowiki>{{TemplateMapping}}</nowiki> dans une page de l'espace de noms '''Mapping_fr:''' suivi du nom du modèle.
| |
- |
| |
- | Par exemple le mapping du modèle [[http://fr.wikipedia.org/wiki/Modèle:Infobox_Arbitre Infobox Arbitre]] est défini dans la page http://mappings.dbpedia.org/index.php/Mapping_fr:Infobox_Arbitre qui contient :
| |
- | <nowiki>{{TemplateMapping
| |
- | | mapToClass = Referee
| |
- | | mappings =
| |
- | {{PropertyMapping | templateProperty = nom | ontologyProperty = foaf:name }}
| |
- | {{PropertyMapping | templateProperty = nom_de_l'arbitre | ontologyProperty = foaf:name }}
| |
- | {{PropertyMapping | templateProperty = surnom | ontologyProperty = foaf:nick }}
| |
- | {{PropertyMapping | templateProperty = date_de_naissance | ontologyProperty = birthDate }}
| |
- | [...]
| |
- | }}</nowiki>
| |
- |
| |
- | Le champ '''mapToClass''' donne la classe a associer au modèle mappé, ici toutes les instances dont l'article Wikipédia contient une [[http://fr.wikipedia.org/wiki/Modèle:Infobox_Arbitre Infobox Arbitre]] prendra le type '''http://dbpedia.org/ontology/Referee'''. La classe doit être définie dans le wiki.
| |
- |
| |
- | Le champ '''mappings''' contient les mappings des attributs (appelés ici ''template properties''). Les mappings d'attributs sont définis dans les modèles [http://mappings.dbpedia.org/index.php/Template:PropertyMapping <nowiki>{{PropertyMapping}}</nowiki>] avec les champs :
| |
- | * '''templateProperty''' : l'attribut du modèle mappé
| |
- | * '''ontologyProperty''' : propriété associée à l'attribut (doit être définie dans le wiki).
| |
- | * '''unit''' permet de spécifier le type de données associé si la propriété est de type ''owl:DatatypeProperty'' (soit un dataype xsd, soit [[#Édition de datatype|défini dans le wiki]])
| |
- | * '''facteur''' permet de multiplier la valeur trouvée par ce facteur, par exemple si un nombre est exprimé en millions.
| |
- |
| |
- |
| |
- | === Mappings constants ===
| |
- |
| |
- | Parfois, certaines propriétés ne sont pas données sous forme d'attribut, mais implicitement par le choix d'un modèle, par exemple l'utilisation du modèle [http://fr.wikipedia.org/wiki/Modèle:Infobox_Commune_de_France Infobox Commune de France] sous-entend que la commune est en France.
| |
- |
| |
- | Le modèle [http://mappings.dbpedia.org/index.php/Template:ConstantMapping <nowiki>{{ConstantMapping}}</nowiki>] qui s'utilise dans le champ '''mappings''' permet d'introduire la propriété implicite:
| |
- | <nowiki>{{TemplateMapping
| |
- | | mapToClass = Settlement
| |
- | | mappings =
| |
- | {{ConstantMapping | ontologyProperty = country | value = France }}
| |
- | {{PropertyMapping | templateProperty = nomcommune | ontologyProperty = foaf:name }}
| |
- | [...]
| |
- | }}</nowiki>
| |
- | La champ '''ontologyProperty''' désigne la propriété à utiliser pour le triplet généré, le champ '''valeur''' contient soit un littéral dans le cas d'une propriété du type ''owl:DatatypeProperty'', soit une instance sans son préfixe (ici '''France''').
| |
- |
| |
- |
| |
- |
| |
- | === Introduction de nœuds intermédiaires ===
| |
- |
| |
- | Il est parfois nécessaire de regrouper des informations, par exemple pour décrire les différents postes occupés par une personnes au cours de sa carrière il faut regrouper la nature du poste avec les dates de début et de fin.
| |
- |
| |
- | En RDF, cela est obtenu en introduisant des nœuds intermédiaires (appelés aussi '''blanc nodes''' s'ils n'ont pas d'identifiant public).
| |
- | Par exemple, l'article sur [http://fr.wikipedia.org/wiki/Arlette_Laguiller Arlette Laguiller] mentionne deux postes :
| |
- | <nowiki>{{Infobox Politicien
| |
- | | nom = Arlette Laguiller
| |
- | [...]
| |
- | | fonction1 = [[Parlement européen|Députée européenne]]
| |
- | | a partir du fonction1 = {{date|20|juillet|1999}}
| |
- | | jusqu'au fonction1 = {{date|19|juillet|2004}}
| |
- | | fonction2 = [[Conseil régional d'Île-de-France|Conseillère régionale d'Île-de-France]]
| |
- | | a partir du fonction2 = {{date|15|mars|1998}}
| |
- | | jusqu'au fonction2 = {{date|28|mars|2004}}
| |
- | [...]
| |
- | }}</nowiki>
| |
- |
| |
- | L'introduction de noeuds intermédiares '''db-fr:Arlette_Laguiller__1''' et '''db-fr:Arlette_Laguiller__2''' permet d'obtenir la représentation suivante :
| |
- | <nowiki>db-fr:Arlette_Laguiller db-owl:occupation db-fr:Arlette_Laguiller__1
| |
- | db-fr:Arlette_Laguiller__1 rdf:type db-owl:PersonFunction
| |
- | db-fr:Arlette_Laguiller__1 db-owl:title "Députée européenne"@fr
| |
- | db-fr:Arlette_Laguiller__1 db-owl:functionStartDate "1999-07-20"
| |
- | db-fr:Arlette_Laguiller__1 db-owl:functionEndDate "2004-07-19"
| |
- | db-fr:Arlette_Laguiller db-owl:occupation db-fr:Arlette_Laguiller__2
| |
- | db-fr:Arlette_Laguiller__2 rdf:type db-owl:PersonFunction
| |
- | db-fr:Arlette_Laguiller__2 db-owl:title "Conseillère régionale d'Île-de-France"@fr
| |
- | db-fr:Arlette_Laguiller__2 db-owl:functionStartDate "1998-03-15"
| |
- | db-fr:Arlette_Laguiller__2 db-owl:functionEndDate "2004-03-28"</nowiki>
| |
- |
| |
- | Cela est obtenu en utilisant un modèle [http://mappings.dbpedia.org/index.php/Template:IntermediateNodeMapping <nowiki>{{IntermediateNodeMapping}}</nowiki>] dans le champ '''mappings'''.
| |
- | Le résultat de l'exemple d'Arlette Laguiller est obtenu avec http://mappings.dbpedia.org/index.php/Mapping_fr:Infobox_Politicien:
| |
- | <nowiki>{{TemplateMapping
| |
- | | mapToClass = OfficeHolder
| |
- | | mappings =
| |
- | {{IntermediateNodeMapping
| |
- | | nodeClass = PersonFunction
| |
- | | correspondingProperty = occupation
| |
- | | mappings =
| |
- | {{PropertyMapping | templateProperty = fonction1 | ontologyProperty = title }}
| |
- | {{PropertyMapping | templateProperty = a partir du fonction1 | ontologyProperty = functionStartDate }}
| |
- | {{PropertyMapping | templateProperty = jusqu'au fonction1 | ontologyProperty = functionEndDate }}
| |
- | }}
| |
- | {{IntermediateNodeMapping
| |
- | | nodeClass = PersonFunction
| |
- | | correspondingProperty = occupation
| |
- | | mappings =
| |
- | {{PropertyMapping | templateProperty = fonction2 | ontologyProperty = title }}
| |
- | {{PropertyMapping | templateProperty = a partir du fonction2 | ontologyProperty = functionStartDate }}
| |
- | {{PropertyMapping | templateProperty = jusqu'au fonction2 | ontologyProperty = functionEndDate }}
| |
- | }}
| |
- | [...]
| |
- | }}</nowiki>
| |
- |
| |
- |
| |
- | === Mappings conditionnels ===
| |
- |
| |
- | Parfois un même modèle est utilisé pour décrire des sujets de type différent qui est spécifié dans un champ.
| |
- | Par exemple le modèle [http://fr.wikipedia.org/wiki/Modèle:Infobox_Prélat_catholique Infobox Prélat catholique] est utilisé pour décrire des prêtes, des cardinaux et des papes, l'attribut '''titre''' précise leur type.
| |
- |
| |
- | Le modèle [http://mappings.dbpedia.org/index.php/Template:ConditionnalMapping <nowiki>{{ConditionnalMapping}}</nowiki>] permet de définir le type à donner aux instances selon la valeur prise par l'attribut '''titre''' :
| |
- | <nowiki>{{ConditionalMapping
| |
- | | cases =
| |
- | {{Condition
| |
- | | templateProperty = titre
| |
- | | operator = equals
| |
- | | value = Pape
| |
- | | mapping = {{TemplateMapping | mapToClass = Pope }}
| |
- | }}
| |
- | {{Condition
| |
- | | templateProperty = titre
| |
- | | operator = equals
| |
- | | value = Cardinal
| |
- | | mapping = {{TemplateMapping | mapToClass = Cardinal }}
| |
- | }}
| |
- | [...]
| |
- | {{Condition
| |
- | | operator = otherwise
| |
- | | mapping = {{TemplateMapping |mapToClass = Cleric }}
| |
- | }}
| |
- |
| |
- | | defaultMappings =
| |
- | {{PropertyMapping | templateProperty = nom | ontologyProperty = foaf:name }}
| |
- | {{PropertyMapping | templateProperty = nom | ontologyProperty = foaf:nick }}
| |
- | {{PropertyMapping | templateProperty = nom naissance | ontologyProperty = birthName }}
| |
- | [...]
| |
- | }}</nowiki>
| |
- |
| |
- | Ce modèle s'utilise par dessus les modèles <nowiki>{{TemplateMapping}}</nowiki>, il contient deux champs :
| |
- | * '''cases''' dans lequel sont données les différentes alternatives, chacune dans un modèle [http://mappings.dbpedia.org/index.php/Template:Condition <nowiki>{{Condition}}</nowiki>].
| |
- | * '''defaultMappings''' qui contient les mappings d'attributs communs à tous les cas (nom trompeur!).
| |
- |
| |
- | Le modèle [http://mappings.dbpedia.org/index.php/Template:Condition <nowiki>{{Condition}}</nowiki>] établissent une condition et les mappings à appliquer si la condition est satisfaite:
| |
- | * le critère est déterminé par le champ '''opertor''' :
| |
- | ** '''isSet''' pour vérifier si un champ est utilisé (champ donné dans '''templateProperty'''),
| |
- | ** '''equals''' et '''contains''' pour comparer le contenu d'un champ (donné dans '''templateProperty''') avec la valeur donnée dans '''value'''
| |
- | ** '''otherwise''' pour la valeur par défaut
| |
- | * le champ '''mappings''' contient les <nowiki>{{TemplateMapping}}</nowiki> à appliquer.
| |
| | | |
| | | |
Ligne 274 : |
Ligne 9 : |
| * Choisir un modèle à mapper dans la liste http://mappings.dbpedia.org/server/statistics/fr/. Les plus fréquents apparaissent en premier, un code de couleur indique l'état de complétude du mapping : du vert pour un mapping qui couvre presque toutes les propriétés, au rouge pour un mapping inexistant. | | * Choisir un modèle à mapper dans la liste http://mappings.dbpedia.org/server/statistics/fr/. Les plus fréquents apparaissent en premier, un code de couleur indique l'état de complétude du mapping : du vert pour un mapping qui couvre presque toutes les propriétés, au rouge pour un mapping inexistant. |
| * Cliquer sur le modèle choisi pour aller sur la page d'édition du mapping, si la page existe, créer la page au besoin. | | * Cliquer sur le modèle choisi pour aller sur la page d'édition du mapping, si la page existe, créer la page au besoin. |
- | * Mapper le type de l'instance : voir [[#Mapping élémentaire d'un modèle|TemplateMapping]] | + | * Mapper le type de l'instance : voir [[Documentation_mappings#Mapping élémentaire d'un modèle|TemplateMapping]] |
- | * Mapper les propriétés : voir [[#Mapping élémentaire d'un modèle|PropertyMapping]] | + | * Mapper les propriétés : voir [[Documentation_mappings#Mapping élémentaire d'un modèle|PropertyMapping]] |
| ** Pour voir la liste des propriétés à mapper : enregister la page de mapping et cliquer sur le lien «''properties are not mapped yet.''» | | ** Pour voir la liste des propriétés à mapper : enregister la page de mapping et cliquer sur le lien «''properties are not mapped yet.''» |
| * Tester le mapping : après avoir enregistré la page, cliquer sur le lien «''Test this mapping''». | | * Tester le mapping : après avoir enregistré la page, cliquer sur le lien «''Test this mapping''». |
C'est le plus difficile.
Cette requête peut être un peu trop lourde pour des modèles fréquemment utilisés, essayer de retirer la ligne avec "filter".
Sinon, ne prenez qu'un échantillon :