La présentation est en train de télécharger. S'il vous plaît, attendez

La présentation est en train de télécharger. S'il vous plaît, attendez

ACCARY-BARBIER / CNAM - Cycle C - 2005-2006 1 1ère partie : Technologies XML  CHAPITRE 1 : XML et DTD  CHAPITRE 2 : Schémas XML  CHAPITRE 3 : XPath.

Présentations similaires


Présentation au sujet: "ACCARY-BARBIER / CNAM - Cycle C - 2005-2006 1 1ère partie : Technologies XML  CHAPITRE 1 : XML et DTD  CHAPITRE 2 : Schémas XML  CHAPITRE 3 : XPath."— Transcription de la présentation:

1 ACCARY-BARBIER / CNAM - Cycle C - 2005-2006 1 1ère partie : Technologies XML  CHAPITRE 1 : XML et DTD  CHAPITRE 2 : Schémas XML  CHAPITRE 3 : XPath et XSLT  CHAPITRE 4 : Applications XML

2 ACCARY-BARBIER / CNAM - Cycle C - 2005-20062 Chapitre 3 : XPath et XSLT  1. Visualisation des documents XML  2. XPath  2.1. Principes  2.2. Les axes  2.3. Les filtres  2.4. Les prédicats  2.5. Fonctions de base  2.5. Exemples  3. XSLT  3.1. Transformation de documents  3.2. Modèle de traitement XSLT  3.3. Eléments constituants un document XSLT  3.4. Conclusion  En savoir plus…

3 ACCARY-BARBIER / CNAM - Cycle C - 2005-20063 Document sans feuille de style N ou M Agatha Christie Policier-C-15 Le chien des Baskerville Sir Arthur Conan Doyle Policier-D-3 Dune Franck Heckbert Fiction-H-1

4 ACCARY-BARBIER / CNAM - Cycle C - 2005-20064 Visualisation  Avec Internet Explorer

5 ACCARY-BARBIER / CNAM - Cycle C - 2005-20065 Document avec feuille de style CSS ou XSL N ou M Agatha Christie Policier-C-15 Le chien des Baskerville Sir Arthur Conan Doyle Policier-D-3 Dune Franck Heckbert Fiction-H-1 OU

6 ACCARY-BARBIER / CNAM - Cycle C - 2005-20066 Feuille de style CSS livre{ display:block; margin-left:10pt; margin-bottom:5pt; font-size:12pt } titre{ margin-right:10pt; color:blue; } auteur{ margin-right:10pt; } ref{ color:red; }

7 ACCARY-BARBIER / CNAM - Cycle C - 2005-20067 Feuille de style XSL Ma bibliotheque

8 ACCARY-BARBIER / CNAM - Cycle C - 2005-20068 Visualisation  CSS sous Internet Explorer  XSL sous Mozilla

9 ACCARY-BARBIER / CNAM - Cycle C - 2005-20069 Chapitre 3 : XPath et XSLT  1. Visualisation des documents XML  2. XPath  2.1. Principes  2.2. Les axes  2.3. Les filtres  2.4. Les prédicats  2.5. Fonctions de base  2.5. Exemples  3. XSLT  3.1. Transformation de documents  3.2. Modèle de traitement XSLT  3.3. Eléments constituants un document XSLT  3.4. Conclusion  En savoir plus…

10 ACCARY-BARBIER / CNAM - Cycle C - 2005-200610 A quoi sert XPath ?  Décrire un modèle de chemin dans l'arbre d'un document à l'aide d'une expression de chemin  Sélectionner l'ensemble des nœuds atteints en suivant tous les chemins conforme à ce modèle, à partir d'un nœud donné  Exploiter les relations généalogiques existant entre les nœuds qui composent le document

11 ACCARY-BARBIER / CNAM - Cycle C - 2005-200611 Objectifs  Localiser – atteindre des fragments du document  Par adressage absolu  Connaissance exacte de la structure manipulée  Chemin complet conduisant aux fragments à atteindre  Par filtrage  Connaissance partielle de la structure manipulée  Atteindre des composants dont on ne connaît pas à priori la position  Informations sur la forme du chemin y conduisant et/ou le contenu des nœuds traversés.

12 ACCARY-BARBIER / CNAM - Cycle C - 2005-200612 Objectifs  Traitement homogène de tous les composants d'un document Éléments – attributs – texte  Atteindre et contraindre :  Un composant même  L'élément Titre ou l'attribut Num  Son modèle de contenu  Un Titre contenant le mot introduction, une Section contenant un Titre  Le chemin pour atteindre un composant (en tenant (éventuellement) compte de son environnement)  Un Titre contenu dans une Section ou un Titre que précède un Paragraphe

13 ACCARY-BARBIER / CNAM - Cycle C - 2005-200613 Utilisations de XPath  XPath est notamment utilisé :  Dans XSL et XSLT pour localiser un nœud précis ou un ensemble de nœuds afin de leur associer une présentation / une transformation  Dans XPointer pour identifier des fragments de documents  Dans XLink pour pointer une cible précise dans un document.  Dans XQuery, pour localiser un nœud précis ou un ensemble de nœuds afin de le(s) post-traiter  Dans XML Schéma pour exprimer les noms de domaines  …

14 ACCARY-BARBIER / CNAM - Cycle C - 2005-200614 Modèle de document  Pour XPath, un document XML est un arbre formé de nœuds de différents types  Document : Nœud racine,  Unique et obligatoire  Distinct de l'élément racine du document  Element : nœud élément,  Attribut : nœud attribut  Text : nœud texte,  ProcessingInstruction : nœud instruction de traitement  Comment : nœud commentaire  nœuds ordonnés selon l'ordre de lecture des constituants du document XML

15 ACCARY-BARBIER / CNAM - Cycle C - 2005-200615 Nœuds élément  Un nœud élément est associé à chaque élément  Il est étiqueté avec le nom de l'élément  Il peut contenir des nœuds éléments et/ou des nœuds texte  Il est impossible d'avoir deux nœuds texte consécutifs  Le contenu de l'élément est ordonné  Remarques :  On peut associer à un nœud élément un ou plusieurs nœuds attributs  Un nœud élément est parent de son nœud attribut mais le nœud attribut n'est pas enfant de son parent…

16 ACCARY-BARBIER / CNAM - Cycle C - 2005-200616 Nœuds attribut et nœuds texte  Un nœud attribut  Il est étiqueté avec le nom de l'attribut  Il contient sa valeur  Il n'existe pas d'ordre entre les nœuds attributs d'un même élément  Un nœud texte est étiqueté avec sa valeur  Remarques :  Les enfants et les descendants d'un nœud ne sont jamais de type attribut

17 ACCARY-BARBIER / CNAM - Cycle C - 2005-200617 Exemple de référence : Structure et balises Prélude à fondation Asimov Isaac Pocket […]

18 ACCARY-BARBIER / CNAM - Cycle C - 2005-200618 Exemple de référence : arbre XPATH Élément bibliothèque Instruction xsl ins1 Comment - blabla Document Élément livre Élément livre Élément titre Élément auteurs Élément éditeur Élément achat Élément auteur Élément prénom Élément nom Attr lang fr Attr ref ASI2002 Text prélude à fondation Text Asimov Text Isaac Text Pocket Attr date 10/11/2003 Attr lieu FNAC Attr type roman Attr genre SF […]

19 ACCARY-BARBIER / CNAM - Cycle C - 2005-200619 Expressions de chemins XPath  Une expression XPath :  S'évalue en fonction d'un nœud contexte  Désigne un ou plusieurs chemins dans l'arbre à partir de ce nœud  A pour résultat un ensemble de nœud ou une valeur numérique, booléenne ou alphanumérique  Parcours dans l'arbre d'un document : suite d'étapes  Un chemin peut être :  Absolu : /livre/achat/@lieu  (contexte = racine du doc)  Relatif : livre/achat/@lieu étape / / Absolu Relatif

20 ACCARY-BARBIER / CNAM - Cycle C - 2005-200620 Étapes XPath  Une étape : trois composants  Un axe : sens de parcours des nœuds  Un filtre : type des nœuds qui seront retenus  Un ensemble de prédicats –facultatifs-: propriétés que doivent satisfaire les nœuds retenus  On peut faire une union de chemins //livre | achat/@lieu Axe ] PrédicatFiltre [::

21 ACCARY-BARBIER / CNAM - Cycle C - 2005-200621 Évaluation d'une expression XPath  Etape évaluée en tenant compte de son contexte :  Nœud, position initiale du chemin 1.Evaluation de l'étape 1 a partir du nœud contexte :  On obtient un ensemble de nœuds  Taille de cet ensemble (fonction last() )  Position du nœud contexte dans cet ensemble (fonction position() ) 2.Evaluation étapes suivante :  On considère un par un, les nœuds de cet ensemble comme nœud contexte pour l'évaluation  A chaque étape, on prend successivement comme nœud contexte chacun des nœuds résultat de l'étape précédente.

22 ACCARY-BARBIER / CNAM - Cycle C - 2005-200622 /A/B/@att1 : nœud initial Élément A C B B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1

23 ACCARY-BARBIER / CNAM - Cycle C - 2005-200623 /A/B/@att1 : première étape Élément A C B B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1

24 ACCARY-BARBIER / CNAM - Cycle C - 2005-200624 /A/B/@att1 : seconde étape Élément A C B B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1

25 ACCARY-BARBIER / CNAM - Cycle C - 2005-200625 /A/B/@att1 : troisième étape Élément A C B B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1

26 ACCARY-BARBIER / CNAM - Cycle C - 2005-200626 Chapitre 3 : XPath et XSLT  1. Visualisation des documents XML  2. XPath  2.1. Principes  2.2. Les axes  2.3. Les filtres  2.4. Les prédicats  2.5. Fonctions de base  2.5. Exemples  3. XSLT  3.1. Transformation de documents  3.2. Modèle de traitement XSLT  3.3. Eléments constituants un document XSLT  3.4. Conclusion  En savoir plus…

27 ACCARY-BARBIER / CNAM - Cycle C - 2005-200627 Axe  Précise la direction à suivre – un sens- pour atteindre les nœuds suivants  Hiérarchie directe, indirecte entre les nœuds  Position relative des nœuds les uns par rapport aux autres  Implique un ordre de parcours des nœuds  Un axe a un type  Attribut  Element  Namespace

28 ACCARY-BARBIER / CNAM - Cycle C - 2005-200628 Les axes XPath  self :: (Notation abrégée :. )  child::nom (Notation abrégée : nom )  attribut:: (Notation abrégée : @ )  parent:: (Notation abrégée :.. )  descendant::  descendant-or-self:: (Notation abrégée : / )  ancestor::  ancestor-or-self::  following::  following-sibling::  preceding::  preceding-sibling::

29 ACCARY-BARBIER / CNAM - Cycle C - 2005-200629 L'axe self::node() Élément A C nœud contexte Élément B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1

30 ACCARY-BARBIER / CNAM - Cycle C - 2005-200630 L'axe child::node() Élément A C nœud contexte Élément B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1

31 ACCARY-BARBIER / CNAM - Cycle C - 2005-200631 L'axe attribute::att1 Élément A C nœud contexte Élément B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1

32 ACCARY-BARBIER / CNAM - Cycle C - 2005-200632 L'axe parent::A Élément A C nœud contexte Élément B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1

33 ACCARY-BARBIER / CNAM - Cycle C - 2005-200633 L'axe descendant::node() Élément A C nœud contexte Élément B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1

34 ACCARY-BARBIER / CNAM - Cycle C - 2005-200634 L'axe descendant-or-self::node() Élément A C nœud contexte Élément B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1

35 ACCARY-BARBIER / CNAM - Cycle C - 2005-200635 L'axe ancestor::node() Élément A C nœud contexte Élément B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1

36 ACCARY-BARBIER / CNAM - Cycle C - 2005-200636 L'axe ancestor-or-self::node() Élément A C nœud contexte Élément B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1

37 ACCARY-BARBIER / CNAM - Cycle C - 2005-200637 L'axe preceding::node() Élément A C nœud contexte Élément B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1

38 ACCARY-BARBIER / CNAM - Cycle C - 2005-200638 L'axe preceding-sibling::node() Élément A C nœud contexte Élément B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1

39 ACCARY-BARBIER / CNAM - Cycle C - 2005-200639 L'axe following::node() Élément A C nœud contexte Élément B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1

40 ACCARY-BARBIER / CNAM - Cycle C - 2005-200640 L'axe following-sibling::node() Élément A C nœud contexte Élément B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1

41 ACCARY-BARBIER / CNAM - Cycle C - 2005-200641 Chapitre 3 : XPath et XSLT  1. Visualisation des documents XML  2. XPath  2.1. Principes  2.2. Les axes  2.3. Les filtres  2.4. Les prédicats  2.5. Fonctions de base  2.5. Exemples  3. XSLT  3.1. Transformation de documents  3.2. Modèle de traitement XSLT  3.3. Eléments constituants un document XSLT  3.4. Conclusion  En savoir plus…

42 ACCARY-BARBIER / CNAM - Cycle C - 2005-200642 Deux types de filtres : sur le nom ou le type  Filtrage sur le nom (valable pour les types de nœuds qui ont un nom) :  Element  ProcessingInstruction  Attributs NOM : nœuds de nom NOM  exemple : /livre/auteurs/auteur  * : tout nœud de l'axe  exemple : /livre/*

43 ACCARY-BARBIER / CNAM - Cycle C - 2005-200643 /A/B/D Élément A C B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1 Élément B

44 ACCARY-BARBIER / CNAM - Cycle C - 2005-200644 Nom générique : /A/* Élément A C B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1 Élément B

45 ACCARY-BARBIER / CNAM - Cycle C - 2005-200645 Filtrage sur le type  text() :  nœuds de type Text  exemple : /livre/titre//text()  comment() :  nœuds de type Comment  exemple : /comment()  processing-instruction() :  nœuds de type ProcessingInstruction  exemple : /processing-instruction('java')  node() :  tous les types de noeuds

46 ACCARY-BARBIER / CNAM - Cycle C - 2005-200646 /A/B//text() Élément A C B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1 Élément B

47 ACCARY-BARBIER / CNAM - Cycle C - 2005-200647 /descendant::node()/@att2 Élément A C B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla Document - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1 Élément B

48 ACCARY-BARBIER / CNAM - Cycle C - 2005-200648 Chapitre 3 : XPath et XSLT  1. Visualisation des documents XML  2. XPath  2.1. Principes  2.2. Les axes  2.3. Les filtres  2.4. Les prédicats  2.5. Fonctions de base  2.5. Exemples  3. XSLT  3.1. Transformation de documents  3.2. Modèle de traitement XSLT  3.3. Eléments constituants un document XSLT  3.4. Conclusion  En savoir plus…

49 ACCARY-BARBIER / CNAM - Cycle C - 2005-200649 Prédicats et chemins  Expressions booléennes construites à partir  D'expressions de chemin  De fonctions prédéfinies.  Expression calculée automatiquement convertie en résultat booléen selon son type et sa valeur.  Valeur numérique  0 ou NAN : prédicat = false.  Autre valeur numérique : prédicat = true.  chaîne de caractères,  Vide : prédicat = false  Non vide : prédicat = true.  Ensemble de nœuds,  Vide : prédicat = false  Non vide : prédicat = true.

50 ACCARY-BARBIER / CNAM - Cycle C - 2005-200650 Pour bien comprendre  Exemples de prédicats avec expressions de chemins  /child::livre/child::titre[attribute::genre]  F.A. : /livre/titre[@genre]  Eléments titre, fils d'éléments livre qui possèdent un attribut genre  /child::livre/child::titre[attribute::type='SF']  F.A. : /livre/titre[@type='SF']  Eléments titre, fils d'éléments livre qui possèdent un attribut type dont la valeur vaut 'SF'.  Dans l'expression /A/B[@att1] :  On s'intéresse aux nœuds de type B fils de l'élément racine A  Parmi ces nœuds on ne prend que ceux pour lesquels le prédicat [@att1] s'évalue à true  [@att1] renverra vrai seulement si l'élément auquel on l'applique (ici B ) possède un attribut att1.

51 ACCARY-BARBIER / CNAM - Cycle C - 2005-200651 /A/B[@att1] Élément A C B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla nœud contexte - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1 Élément B

52 ACCARY-BARBIER / CNAM - Cycle C - 2005-200652 /A/B[@att1='a1'] Élément A C B D D D Instruction Java ins1 Comment - blabla Text - blabla Text - blabla Text - blabla nœud contexte - Attr att2 a3 Attr att1 a2 Attr att3 15 Attr att1 a1 Élément B

53 ACCARY-BARBIER / CNAM - Cycle C - 2005-200653 Prédicats et fonctions  Les prédicats peuvent également utiliser des fonctions prédéfinies de XPath pour vérifier des conditions sur les nœuds.  Exemples de prédicats utilisant des fonctions  /child::auteurs/descendant::text()[position()=1]  F.A. : /auteurs//text()[1]  Premier nœud de type Text descendant d'un élément auteurs  Syntaxe abrégée : [position()=1] s'écrit [1].  /child::titre[count(descendant::auteur)≥2]  F.A. : /titre[count(//auteur) ≥ 2]  Eléments titre qui ont au moins 2 descendants de type auteur

54 ACCARY-BARBIER / CNAM - Cycle C - 2005-200654 Chapitre 3 : XPath et XSLT  1. Visualisation des documents XML  2. XPath  2.1. Principes  2.2. Les axes  2.3. Les filtres  2.4. Les prédicats  2.5. Fonctions de base  2.5. Exemples  3. XSLT  3.1. Transformation de documents  3.2. Modèle de traitement XSLT  3.3. Eléments constituants un document XSLT  3.4. Conclusion  En savoir plus…

55 ACCARY-BARBIER / CNAM - Cycle C - 2005-200655 Fonctions appliquées aux noeuds  count(ensemble_de_nœuds)  Compte le nombre de nœuds référencés.  Il existe également des fonctions permettant de positionner un nœud par rapport à ses frères.  position(ensemble_de_nœuds)  Retourne la position du nœud contextuel.  last(ensemble_de_nœuds)  Retourne la position du dernier nœud d'un ensemble de nœuds.  name(nœuds)  Renvoie le nom du nœud contexte.  string(nœud)  Retourne le texte du nœud sans balisage

56 ACCARY-BARBIER / CNAM - Cycle C - 2005-200656 Fonctions sur les chaînes de caractères (1/2)  concat(chaine1, chaine2, chaine, …)  concatène toutes les chaînes passées en arguments  Fonctions booléennes pour savoir si une chaîne est incluse dans une autre.  starts-with(chaine1, chaine2)  true si chaine1 est débutée par chaine2  contains(chaine1, chaine2)  true si chaine1 contient chaine2.  string-length(chaine)  Renvoie la longueur de chaîne.  Utilisée sans argument, la fonction renvoie la longueur de la valeur textuelle du nœud courant.

57 ACCARY-BARBIER / CNAM - Cycle C - 2005-200657 Fonctions sur les chaînes de caractères (2/2)  Extraction d'une sous-chaîne à partir d'une chaîne  substring(chaine1, m, n)  Sous-chaîne de chaine1 contenant n caractères et commençant au caractère en position m.  substring-after(chaine1, chaine2)  Sous-chaîne de chaine1 qui suit la première occurrence de chaine2.  substring-before(chaine1, chaine2)  Sous-chaîne de chaine1 qui précède la première occurrence de chaine2.  translate(chaine1, chaine2, chaine3)  Remplace dans chaine1 chaque occurrence des caractères de chaine2 par ceux de chaine3.  Ex : translate(chaine, "abcdefghijklmnopqrstuvwxyz", "ABCDEFGHIJKLMNOPQRSTUVWXYZ")  Conversion de chaine en majuscule.

58 ACCARY-BARBIER / CNAM - Cycle C - 2005-200658 Fonctions booléennes  true(), false() et not().  lang(chaine)  true si la valeur de l'attribut xml:lang du nœud courant = celle reçue en argument.  boolean(objet)  Conversion en valeur booléenne selon le type :  Numériques –0 ou NaN = false –tout le reste est true  Chaînes –chaîne vide = false –tout le reste est true  Ensembles de noeuds –ensemble vide = false –tout le reste est true

59 ACCARY-BARBIER / CNAM - Cycle C - 2005-200659 Fonctions numériques  Opérateurs numériques courants :  Comparaisons :, =, !=  Opérations : +, -, *, div, mod  Fonctions numériques :  number()  Tente une conversion (en cas d'echec on obtient NaN)  ceiling(nombre)  Retourne le plus petit entier égal ou supérieur à nombre.  floor(nombre)  Plus grand entier égal ou inférieur à nombre  round(nombre)  Arrondit nombre à l'entier le plus proche  sum(nombre1, nombre2,...)  Somme les nombres/valeurs des nœuds passés en argument.

60 ACCARY-BARBIER / CNAM - Cycle C - 2005-200660 Chapitre 3 : XPath et XSLT  1. Visualisation des documents XML  2. XPath  2.1. Principes  2.2. Les axes  2.3. Les filtres  2.4. Les prédicats  2.5. Fonctions de base  2.5. Exemples  3. XSLT  3.1. Transformation de documents  3.2. Modèle de traitement XSLT  3.3. Eléments constituants un document XSLT  3.4. Conclusion  En savoir plus…

61 ACCARY-BARBIER / CNAM - Cycle C - 2005-200661 Bilan  XPath est un mécanisme standard de filtrage puissant et complet  La localisation d'un composant peut être exprimée par  Chemin absolu (connaissance exacte de la structure)  Modèle de chemin à suivre (connaissance partielle de la structure)  Mécanisme essentiel pour un langage d'interrogation, de manipulation  Moyen de filtrer les composants du document quel que soit leur type  Necessité d'un jeu d'opérateurs pour exploiter ces données

62 ACCARY-BARBIER / CNAM - Cycle C - 2005-200662 Exemples d'expressions XPath(1)  child::livre[position()=last()–1]  F.A. : livre[last()-1)]  avant dernier livre du nœud contexte  following-sibling::livre[position()=1]  F.A. : following-sibling::B[1]  premier frère de droite de type livre du nœud contexte  descendant::livre[position()=12]  F.A. : //livre[12]  douzième livre du document

63 ACCARY-BARBIER / CNAM - Cycle C - 2005-200663 Exemples d'expressions XPath(2)  child::livre[child::éditeur and descendant::titre[attibut::genre='SF']]  F.A. : livre[éditeur and titre[@genre='SF']]  tout livre avec un éditeur et dont le genre est Science Fiction.  descendant::nom[child::text()='Asimov']/anc estor::titre  F.A. : //nom[text()='Asimov']/..titre  tous les titres des livres dont le nom d'un auteur est Asimov.  [self::auteur | self::éditeur]  tout élément fils du nœud contexte qui est soit un auteur, soit un éditeur.

64 ACCARY-BARBIER / CNAM - Cycle C - 2005-200664 Chapitre 3 : XPath et XSLT  1. Visualisation des documents XML  2. XPath  2.1. Principes  2.2. Les axes  2.3. Les filtres  2.4. Les prédicats  2.5. Fonctions de base  2.5. Exemples  3. XSLT  3.1. Transformation de documents  3.2. Modèle de traitement XSLT  3.3. Eléments constituants un document XSLT  3.4. Conclusion  En savoir plus…

65 ACCARY-BARBIER / CNAM - Cycle C - 2005-200665 Introduction à XSLT  XSLT est un langage pour transformer des documents XML en d’autres documents XML  Développé par le W3C, initialement pour le langage de formatage XSL  Recommandation W3C depuis novembre 1999  XSLT 2.0 en cours de développement  Utilise la syntaxe XML, utilise le langage d’expressions XPath  Même type de document ou types différents en entrée et en sortie  XSLT peut être utilisé dans une chaîne de traitement qui utilise aussi Java, Javascript, ASP, PHP, etc.

66 ACCARY-BARBIER / CNAM - Cycle C - 2005-200666 Les feuilles de style XSLT  Les feuilles de style XSL (eXtensible Stylesheet Language)  contrôlent la mise en page du document  Comme les feuilles de style CSS  Indiquent comment un fichier XML doit être transformé en un autre fichier XML ou HTML  Ce sont des documents bien formés  déclaration XML en première ligne  déclaration de l'encodage  règles de fermeture des balises, etc.

67 ACCARY-BARBIER / CNAM - Cycle C - 2005-200667 Principe  Un document (arbre) source est transformé en un document (arbre) résultat par un moteur de transformation qui applique une feuille de transformation(ou de style)  Fichier XML (+ DTD éventuellement) = D  Feuille de style XSL = F  Processeur XSL = programme qui applique la feuille de style au fichier = P  Le processeur P transforme D en D' grâce à F D + FD' P

68 ACCARY-BARBIER / CNAM - Cycle C - 2005-200668 Intérêt de XSL  Plusieurs feuilles de style pour un même document  Caractéristiques d'affichage et de contenu adaptées aux besoins  Contenu adapté pour un type d'utilisateur, d'usage  Affichage adapté selon les plateformes  Exemple d'adaptation sur le fond : fiches bibliographiques en HTML  Affichage détaillé  Affichage résumé  Catalogue de toutes les fiches  Exemple d'adaptation sur la forme : météo en ligne  Ecran 19 pouces : cartes météorologiques, informations détaillées  Téléphone portable : police reduite, informations importantes seulement, pas de cartes

69 ACCARY-BARBIER / CNAM - Cycle C - 2005-200669 Rôle du processeur XSL Feuille de style XSL n°1 Feuille de style XSL n°2 Fichier XML initial (bien formé ou valide) Fichier XML résultat (transformé) n°1 Fichier XML résultat (transformé) n°2 Processeur XSL

70 ACCARY-BARBIER / CNAM - Cycle C - 2005-200670 Chapitre 3 : XPath et XSLT  1. Visualisation des documents XML  2. XPath  2.1. Principes  2.2. Les axes  2.3. Les filtres  2.4. Les prédicats  2.5. Fonctions de base  2.5. Exemples  3. XSLT  3.1. Transformation de documents  3.2. Modèle de traitement XSLT  3.3. Eléments constituants un document XSLT  3.4. Conclusion  En savoir plus…

71 ACCARY-BARBIER / CNAM - Cycle C - 2005-200671 Structure de base : les règles  Règle = template : élément de base pour produire le résultat  Une règle s'applique dans le contexte d'un nœud de l'arbre  L'application de la règle produit un fragment du résultat  Résultat global (arbre) construit par la hiérarchisation des règles.  Eléments de l'arbre source XML  Eléments non filtrés  organisés dans un ordre différent,  Eléments nouveaux créés par les règles.

72 ACCARY-BARBIER / CNAM - Cycle C - 2005-200672 Résultats de transformation  Règles en deux parties  motif (Pattern) a rechercher dans l'arbre source  Dépend du contexte structural dans l’arbre source  Exprimé dans le langage XPath  modèle utilisé pour former l'arbre résultat  Exemple de règle Je suis maintenant dans un nœud de nom "titre".  Motif de sélection : expression match="titre"  Modèle de la règle = contenu de l'élément  Résultat : affichage dans le document du texte " Je suis maintenant dans un nœud de nom "titre" "

73 ACCARY-BARBIER / CNAM - Cycle C - 2005-200673 Structure d'une feuille XSLT <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">http://www.w3.org/1999/XSL/Transform … INSTRUCTIONS-OU-BALISES-OU-TEXTE … … INSTRUCTIONS-OU-BALISES-OU-TEXTE … … AUTANT DE BLOCS XSL:TEMPLATE QUE NECESSAIRE … bloc 1 début bloc 2 fin

74 ACCARY-BARBIER / CNAM - Cycle C - 2005-200674 Processus de transformation XSLT  Analyse (parcours) du document source nœud par nœuds  Recherche d'une règle définie dans la feuille de style  Application des instructions contenues dans cette règle  Une règle trouvée, elle est appliquée  Plusieurs règles applicables :  Règles issues de 2 feuilles de style (importation feuille externe).  Priorité d’importation (élément )  La feuille qui importe est prioritaire sur la feuille importée  Règles de la même feuille : la + prioritaire est choisie  Attribut priority de la règle,  Sélectivité du pattern : règle la plus précise = la plus prioritaire  Aucune règle : règle par défaut selon le type du nœud

75 ACCARY-BARBIER / CNAM - Cycle C - 2005-200675 Règles par défaut  Nœuds de type élément de l'arbre XML,  Relance l'application des règles de la feuille au nœud racine ou aux fils du nœud (traitement récursif).  Nœuds de type text() et attribut(),  Recopie le texte ou la valeur de l'attribut.  Nœuds de type processing-instruction() et comment()  Ne rien faire.

76 ACCARY-BARBIER / CNAM - Cycle C - 2005-200676 Modèle général de feuille de style XSLT  Appel des règles hiérarchique.  Règle initiale qui s’applique à la racine du document traité (’/’).  Production du cadre du document résultat  Appel des autres règles qui vont, quant à elles, produire le contenu du document résultat.  Règles secondaires effectuent des traitements seulement sur les nœuds qu'elles ciblent  Modification de la mise en page du résultat.

77 ACCARY-BARBIER / CNAM - Cycle C - 2005-200677 Exemple : biblio.xsl construction du cadre HTML du document résultat à afficher -->

78 ACCARY-BARBIER / CNAM - Cycle C - 2005-200678 Exemple : Règle générale Ma bibliotheque Ma bibliothèque

79 ACCARY-BARBIER / CNAM - Cycle C - 2005-200679 Exemple : Règle secondaire "livre" (1/2) (type :, genre : ) aux éditions

80 ACCARY-BARBIER / CNAM - Cycle C - 2005-200680 Exemple : Règle secondaire "livre" (2/2) ( Ce livre est en français Ce livre est en anglais Ce livre est en langue inconnue. )

81 ACCARY-BARBIER / CNAM - Cycle C - 2005-200681 Exemple : Règle secondaire "auteur"

82 ACCARY-BARBIER / CNAM - Cycle C - 2005-200682 Résultat

83 ACCARY-BARBIER / CNAM - Cycle C - 2005-200683 Chapitre 3 : XPath et XSLT  1. Visualisation des documents XML  2. XPath  2.1. Principes  2.2. Les axes  2.3. Les filtres  2.4. Les prédicats  2.5. Fonctions de base  2.5. Exemples  3. XSLT  3.1. Transformation de documents  3.2. Modèle de traitement XSLT  3.3. Eléments constituants un document XSLT  3.4. Conclusion  En savoir plus…

84 ACCARY-BARBIER / CNAM - Cycle C - 2005-200684 Déclaration et élément racine  Feuille XSLT : document XML (déclaration XML)  Elément document (racine) : xsl:stylesheet  Doit être déclaré juste après le prologue du document  Contient tous les autres éléments du document.  Attribut version : numéro de version de la feuille  Attribut xmlns:xsl : espace de nom utilisé pour la feuille  Éléments fils possibles (top-level elements)  Ordre quelconque (sauf import et output en tête) :  import, include, strip-space, preserve-space, output, key, decimal-format, namespace-alias, attribute-set, variable, param, template

85 ACCARY-BARBIER / CNAM - Cycle C - 2005-200685 Eléments de base : xsl:output  spécifie les options de l'arbre de sortie  Attributs possibles :  method : méthode de transformation.  version : version de la méthode de sortie (xml 1.0, html 4.01).  encoding : version du jeu de caractères à utiliser pour la sortie.  omit-xml-declaration : prise en compte de la déclaration XML.  standalone : arbre de sortie avec ou sans DTD.  doctype-public : identifiant public utilisé par la DTD associée.  doctype-system : identifiant system utilisé par la DTD associée.  cdata-section-elements : éléments dont le contenu doit être traité via une section CDATA.  indent : transformation sous forme d'arbre si valeur = yes.  media-type : type MIME des données résultantes.

86 ACCARY-BARBIER / CNAM - Cycle C - 2005-200686 Eléments de base : xsl:templates  définit un modèle / règle à appliquer à un nœud et à un contexte spécifiques.  Attributs :  name (facultatif) : nom donné à la règle en vu d'un appel explicite par l’instruction dans un autre élément.  match : Nœuds sources auxquels la règle s'applique.  Valeur = ensemble de chemins XPath séparés par des ’|’ (union).  Seuls les axes child et attribute et les opérateurs // et / sont permis.  mode (facultatif) : permet d'avoir plusieurs règles en fonction du mode de sortie. { contenu de la règle }

87 ACCARY-BARBIER / CNAM - Cycle C - 2005-200687 Eléments de base : xsl:apply-templates  relance l'application des règles sur les nœuds-fils de l'élément dans le traitement duquel il est appelé.  select (facultatif)  Absent : traitement de tous les fils du nœud courant (y compris nœuds texte).  Présent : traitement uniquement des nœuds de l'expression  peut être vide.  Le traitement des nœuds-fils utilisera,  Les règles définies dans la feuille de style pour ces éléments si elles existent,  Les règles par défaut.  Ex : Dans biblio.xsl, l'appel dans la règle principale permet aux autres règles d'être exécutées.

88 ACCARY-BARBIER / CNAM - Cycle C - 2005-200688 Eléments de base : xsl:value-of  recopie la valeur d'une expression  Expression peut correspondre à un élément, à un attribut ou à tout autre nœud contenant une valeur.  select : chemin du nœud dont on veut copier le contenu.  recopie le nœud (balisage compris)  Ex : Dans biblio.xsl, permet de recopier la valeur des nœuds "éditeur" parcourus.

89 ACCARY-BARBIER / CNAM - Cycle C - 2005-200689 Boucles et choix : xsl:for-each  permet de créer une boucle dans laquelle sont appliquées un certain nombre de transformations.  select : définit l'ensemble des nœuds devant être parcouru par la boucle.  prend les nœuds un par un comme nœud contexte  Ex : Dans biblio.xsl, l'exemple suivant permet de recopier à la suite la valeur de tous les nœuds "auteur" parcourus.

90 ACCARY-BARBIER / CNAM - Cycle C - 2005-200690 Boucles et choix : xsl:sort  permet d'effectuer un tri sur un ensemble de nœuds.  Utilisé dans et  Peut être appelé plusieurs fois pour effectuer un tri multicritères.  attributs :  select : spécifie un nœud comme clé de tri.  data-type (facultatif) : type des données à trier.  order : ordre du tri.  lang (facultatif) : jeu de caractères à utiliser pour le tri.  case-order (facultatif) : tri sur les majuscules ou minuscules  Ex : Dans biblio.xsl, l'exemple suivant permet de recopier à la suite la valeur de tous les nœuds "auteur" parcourus mais en les classant par ordre alphabétique.

91 ACCARY-BARBIER / CNAM - Cycle C - 2005-200691 Boucles et choix : xsl:if  permet d'effectuer des tests sur les attributs et les éléments du document XML.  test : prend la valeur 1 ou 0 selon le résultat de l'évaluation de la condition (true ou false).  En cas de réussite au test, le contenu de l'élément est appliqué.  Pas de else…  Ex : Dans biblio.xsl, l'exemple suivant permet de tester si l'attribut genre existe et de l'afficher seulement en cas de réussite au test., genre : action

92 ACCARY-BARBIER / CNAM - Cycle C - 2005-200692 Boucles et choix : xsl:choose , et permettent de définir une liste de choix et d'affecter à chaque choix une transformation différente.  Chaque choix est défini par un élément  Un traitement par défaut peut être spécifié grâce à l'élément.  Ex : Dans biblio.xsl, l'exemple suivant permet de tester la valeur de l'attribut lang et d'afficher des résultats différents en fonction de la réponse au test. Ce livre est en français Ce livre est en anglais Ce livre est dans une langue non répertoriée.

93 ACCARY-BARBIER / CNAM - Cycle C - 2005-200693 Création : xsl:element et xsl:attribute  permet d'insérer un nouvel élément dans l'arbre résultat  name : nom donné au nouvel élément.  use-attribute-sets : ensemble des attributs à associer à l'élément créé.  permet de définir un nouvel attribut à ajouter à l'élément de l'arbre résultat.  name : nom de l'attribut à ajouter dans le contexte courant.  Valeur de l'attribut créé = celle du contenu de l'élément valeur

94 ACCARY-BARBIER / CNAM - Cycle C - 2005-200694 Définition de variables : xsl:variable  sert à créer les variables dans XSLT.  name : spécifie le nom de la variable.  Plusieurs possibilités de contenu(valeur de la variable) :  select avec une valeur (une constante)  select avec une expression XPath  Variable définie par son contenu :  voici le contenu de la variable  Appel à la variable se fait avec $nom_variable 

95 ACCARY-BARBIER / CNAM - Cycle C - 2005-200695 Portée d'une variable  Portée d'une variable limitée aux éléments-frères et à leurs descendants.  Si une variable est déclarée dans une boucle ou un choix, on ne pourra pas l'utiliser hors de cet élément.  Deux types de variables :  variables globales (élément de premier niveau).  visibles dans tout le programme XSLT  avant le template  variables locales (dans les corps de règle).  visibles dans les following-sibling et leur descendants  après le template

96 ACCARY-BARBIER / CNAM - Cycle C - 2005-200696 Définition de paramètres : xsl:param  permet de créer un paramètre qui peut ensuite être passé à une règle grâce à  name : spécifie le nom de la variable  select : donne la valeur par défaut du paramètre.  Deux niveaux de définition :  Dans le corps d'une règle (local)  Fourni par l'appel de règle ( call ou apply )  Élément de premier niveau (global)  Fils de xsl:stylesheet  Appel au parametre se fait avec $nom_param 

97 ACCARY-BARBIER / CNAM - Cycle C - 2005-200697 Exemple de paramètre  La règle Afficher attend une chaîne :  Passage du paramètre :

98 ACCARY-BARBIER / CNAM - Cycle C - 2005-200698 Chapitre 3 : XPath et XSLT  1. Visualisation des documents XML  2. XPath  2.1. Principes  2.2. Les axes  2.3. Les filtres  2.4. Les prédicats  2.5. Fonctions de base  2.5. Exemples  3. XSLT  3.1. Transformation de documents  3.2. Modèle de traitement XSLT  3.3. Eléments constituants un document XSLT  3.4. Conclusion  En savoir plus…

99 ACCARY-BARBIER / CNAM - Cycle C - 2005-200699 Conclusion sur XSLT  Un langage de règles totalement adapté au traitement de documents XML  Parcours d’un document, vu comme un arbre  Déclenchement de règles sur certains nœuds  Association de plusieurs programmes à un même document  Intégration du langage XPath

100 ACCARY-BARBIER / CNAM - Cycle C - 2005-2006100 Chapitre 3 : XPath et XSLT  1. Visualisation des documents XML  2. XPath  2.1. Principes  2.2. Les axes  2.3. Les filtres  2.4. Les prédicats  2.5. Fonctions de base  2.5. Exemples  3. XSLT  3.1. Transformation de documents  3.2. Modèle de traitement XSLT  3.3. Eléments constituants un document XSLT  3.4. Conclusion  En savoir plus…

101 ACCARY-BARBIER / CNAM - Cycle C - 2005-2006101 En savoir plus…  Cours et tutoriels en ligne ….  http://www.xmltechno.com/tutoriels/02_intro_p1.cfm  http://www.w3.org/  Bernd Amann et Philippe Rigaux, 2002, Comprendre XSLT, O'Reilly


Télécharger ppt "ACCARY-BARBIER / CNAM - Cycle C - 2005-2006 1 1ère partie : Technologies XML  CHAPITRE 1 : XML et DTD  CHAPITRE 2 : Schémas XML  CHAPITRE 3 : XPath."

Présentations similaires


Annonces Google