data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
Transformation:
XPath and XSLT
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:tei="http://www.tei-c.org/ns/1.0"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
version="2.0">
<xsl:output method="html"/>
<xsl:template match="tei:TEI">
<html>
<head>
<meta charset="UTF-8"/>
</head>
<body>
<xsl:apply-templates/>
</body>
</html>
</xsl:template>
Tiziana Mancinelli
University of Bologna
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:tei="http://www.tei-c.org/ns/1.0"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
version="2.0">
<xsl:output method="html"/>
<xsl:template match="tei:TEI">
<html>
<head>
<meta charset="UTF-8"/>
</head>
<body>
<xsl:apply-templates/>
</body>
</html>
</xsl:template>
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
Aims of today's laboratory:
- Investigate the structure of TEI/XML documents
- Transform and visualise our TEI/XML
- Therefore - we learn basic syntax of XSLT and XPATH
- create different outputs with XSLT
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:tei="http://www.tei-c.org/ns/1.0"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
version="2.0">
<xsl:output method="html"/>
<xsl:template match="tei:TEI">
<html>
<head>
<meta charset="UTF-8"/>
</head>
<body>
<xsl:apply-templates/>
</body>
</html>
</xsl:template>
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
Transformation
data:image/s3,"s3://crabby-images/2bdfc/2bdfc5387d8d502a44684849dc7ecfafb68e7384" alt=""
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="2.0">
<xsl:output method="xhtml"
doctype-system="http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"/>
<xsl:template match="/">
<html>
<head>
<title><xsl:value-of select="//title"/>
written by <xsl:value-of select="//author"/></title>
</head>
<body>
<xsl:apply-templates/>
</body>
</html>
</xsl:template>
<xsl:template match="title">
<h1>
<xsl:apply-templates/>
</h1>
</xsl:template>
<xsl:template match="author">
<p><i>
<xsl:apply-templates/>
</i></p>
</xsl:template>
<xsl:template match="stanza">
<xsl:apply-templates/>
<br/>
</xsl:template>
<xsl:template match="line">
<div>
<xsl:apply-templates/>
</div>
</xsl:template>
</xsl:stylesheet>
An example:
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:tei="http://www.tei-c.org/ns/1.0"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
version="2.0">
<xsl:output method="html"/>
<xsl:template match="tei:TEI">
<html>
<head>
<meta charset="UTF-8"/>
</head>
<body>
<xsl:apply-templates/>
</body>
</html>
</xsl:template>
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
XSL (eXtensible Stylesheet Language)
is a styling language for XML.
XSLT stands for XSL Transformations.
FROM XML to DIFFERENT OUTPUTS
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:tei="http://www.tei-c.org/ns/1.0"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
version="2.0">
<xsl:output method="html"/>
<xsl:template match="tei:TEI">
<html>
<head>
<meta charset="UTF-8"/>
</head>
<body>
<xsl:apply-templates/>
</body>
</html>
</xsl:template>
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
XSL (eXtensible Stylesheet Language)
is a styling language for XML.
Transformations
to DIFFERENT OUTPUTS
HTML
TXT
XML
ePub
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:tei="http://www.tei-c.org/ns/1.0"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
version="2.0">
<xsl:output method="html"/>
<xsl:template match="tei:TEI">
<html>
<head>
<meta charset="UTF-8"/>
</head>
<body>
<xsl:apply-templates/>
</body>
</html>
</xsl:template>
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
Transformation
data:image/s3,"s3://crabby-images/41458/4145890ed5728fdc7e82931952cd6118a094d2d3" alt=""
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:tei="http://www.tei-c.org/ns/1.0"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
version="2.0">
<xsl:output method="html"/>
<xsl:template match="tei:TEI">
<html>
<head>
<meta charset="UTF-8"/>
</head>
<body>
<xsl:apply-templates/>
</body>
</html>
</xsl:template>
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
-
Xpath interrogates and navigates XML documents
-
XSLT depends on it
What You Should Already Know
Before you continue you should have a basic understanding of the following:
- HTML
- CSS
- XML
data:image/s3,"s3://crabby-images/cf53b/cf53b1d849ae6d6c031f074fe61385b8b295700b" alt=""
First exercise
Let's make our first transformation with default XSLT within oXygen!
- Open your XML file
- Let's create our first SCENARIO
HOW makes "scenarios"
data:image/s3,"s3://crabby-images/f922a/f922ab16c93e8ed76c9ea2383f8bbc5228c70918" alt=""
- click on the tool icon
HOW makes "scenarios"
data:image/s3,"s3://crabby-images/57336/573366b480dc0cd1884256eb232011e9b11431f9" alt=""
2. Click on the format you would like to choose (HTML/PDF)
HOW makes "scenarios"
data:image/s3,"s3://crabby-images/57336/573366b480dc0cd1884256eb232011e9b11431f9" alt=""
3.
How to use XSLTransform plugin in Atom
data:image/s3,"s3://crabby-images/9a071/9a07125556302503714266660423f62ce09f71bf" alt=""
Download the plugin
How to use XSLTransform plugin in Atom
data:image/s3,"s3://crabby-images/9a90b/9a90b7a55ba7bfb0acf6793a5a34a0b232c3f36b" alt=""
Download the plugin
How to use XSLTransform plugin in Atom
data:image/s3,"s3://crabby-images/957bb/957bb490e020e2da25ad6e9d5d8dd64c13d76d43" alt=""
Download the plugin
How to use XSLTransform plugin in Atom
Apply XSLT with Atom
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
what to do to navigate an XML documenti and transform ITS elements in something ELSE?
We are going to transform our XML into HTML
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
Navigate around the tree, selecting nodes by a variety of criteria
data:image/s3,"s3://crabby-images/5b781/5b7815f119ee9162f7d6269ccee32745708a9f7e" alt=""
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:tei="http://www.tei-c.org/ns/1.0"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
version="2.0">
<xsl:output method="html"/>
<xsl:template match="tei:TEI">
<html>
<head>
<meta charset="UTF-8"/>
</head>
<body>
<xsl:apply-templates/>
</body>
</html>
</xsl:template>
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
XPath is a major element in the XSLT standard.
XSLT uses XPath to find information in an XML document.
XPath can be used to navigate through elements and attributes in an XML document.
A language to describe how to locate a part of an XML document
Used in many XML-based technologies and tools
data:image/s3,"s3://crabby-images/f0e8e/f0e8ef1da197c7f81fc22ff14b2f3e023fbdb173" alt=""
What is XPath?
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:tei="http://www.tei-c.org/ns/1.0"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
version="2.0">
<xsl:output method="html"/>
<xsl:template match="tei:TEI">
<html>
<head>
<meta charset="UTF-8"/>
</head>
<body>
<xsl:apply-templates/>
</body>
</html>
</xsl:template>
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
How XPath works
In XPath, there are seven kinds of nodes: element, attribute, text, namespace, processing-instruction, comment, and document nodes.
XML documents are treated as trees of nodes. The topmost element of the tree is called the root element.
data:image/s3,"s3://crabby-images/f0e8e/f0e8ef1da197c7f81fc22ff14b2f3e023fbdb173" alt=""
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:tei="http://www.tei-c.org/ns/1.0"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
version="2.0">
<xsl:output method="html"/>
<xsl:template match="tei:TEI">
<html>
<head>
<meta charset="UTF-8"/>
</head>
<body>
<xsl:apply-templates/>
</body>
</html>
</xsl:template>
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
Expression | Description |
---|---|
nodename | Selects all nodes with the name "nodename" |
/ | Selects from the root node |
// | Selects nodes in the document from the current node that match the selection no matter where they are |
. | Selects the current node |
.. | Selects the parent of the current node |
@ | Selects attributes |
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:tei="http://www.tei-c.org/ns/1.0"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
version="2.0">
<xsl:output method="html"/>
<xsl:template match="tei:TEI">
<html>
<head>
<meta charset="UTF-8"/>
</head>
<body>
<xsl:apply-templates/>
</body>
</html>
</xsl:template>
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
Wildcard | Description |
---|---|
* | matches any element node |
@* | matches any attribute node |
node() | matches any node |
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:tei="http://www.tei-c.org/ns/1.0"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
version="2.0">
<xsl:output method="html"/>
<xsl:template match="tei:TEI">
<html>
<head>
<meta charset="UTF-8"/>
</head>
<body>
<xsl:apply-templates/>
</body>
</html>
</xsl:template>
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
A bare-bones path expression is similar to filesystem addressing: if the path starts with a solidus (/ aka forward slash), then it represents a path from the root; if it does not start with a solidus then it represents a path from here
/TEI/teiHeader/fileDesc/titleStmt/title
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:tei="http://www.tei-c.org/ns/1.0"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
version="2.0">
<xsl:output method="html"/>
<xsl:template match="tei:TEI">
<html>
<head>
<meta charset="UTF-8"/>
</head>
<body>
<xsl:apply-templates/>
</body>
</html>
</xsl:template>
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
body
div
div
head
head
lg
lg
lg
lg
lg
lg
TEI/XML structure
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:tei="http://www.tei-c.org/ns/1.0"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
version="2.0">
<xsl:output method="html"/>
<xsl:template match="tei:TEI">
<html>
<head>
<meta charset="UTF-8"/>
</head>
<body>
<xsl:apply-templates/>
</body>
</html>
</xsl:template>
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
body
div
div
head
head
lg
lg
lg
lg
lg
lg
TEI/XML structure
/body/div/
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
data:image/s3,"s3://crabby-images/f922a/f922ab16c93e8ed76c9ea2383f8bbc5228c70918" alt=""
Toolbar in oXygen
Let's open the file:
pilot-proemio.xml
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
some xpath
/TEI/teiHeader/fileDesc/titleStmt/respStmt/name
Ensure the box is labelled XPath 2.0 (or XPath 3.0). Then type in
/TEI/teiHeader/fileDesc/titleStmt/respStmt/name
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
some xpath
//p
// Selects nodes in the document from the current node that match the selection no matter where they are
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
some xpath
//del/@hand
@ Selects attributes
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
Some Xpath
//del[@hand='overwritten']
[ ] square brackets are used to create conditions
Take all the 'del' elements with an attribute 'hand' with value 'overwritten'
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
count(//del[@type='overwritten'])
xpath has function
What is a function?
In programming, a named section of a program that performs a specific task
Some Xpath
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
ancestor
ancestor-or-self
attribute
child
descendant
descendant-or-self
following
following-sibling
namespace
parent
preceding
preceding-sibling
self
axes
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
An axis (plural axes) is a set of nodes relative to a given node; X::Y means “choose Y from the X axis”
self:: is the set of current nodes (not too useful) self::node() is the current node
child:: is the default
/child::X is the same as /X
parent:: is the parent of the current node
ancestor:: is all ancestors of the current node, up to and including the root
descendant:: is all descendants of the current node (Note: never contains attribute or namespace nodes)
preceding:: is everything before the current node in the entire XML document
following:: is everything after the current node in the entire XML document
Axes
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
examples
data:image/s3,"s3://crabby-images/fed97/fed977dbba4212244438d4dcae3218da7687d33a" alt=""
example:
//pb[@facs="#p21r"]/ancestor::div
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
Equality tests
- = means “equal to” (Notice it’s not ==)
- != means “not equal to”
- But it’s not that simple!
- value = node-set will be true if the node-set contains any node with a value that matches value
-
value != node-set will be true if the node-set contains any node with a value that does not match value
- Hence,
- value = node-set and value != node-set may both be true at the same time!
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
Other boolean operators
- and (infix operator)
- or (infix operator)
- Example: count = 0 or count = 1
- not() (function)
- The following are used for numerical comparisons only:
- < “less than” Some places may require <
- <= “less than Some places may require <= or equal to”
- > “greater than” Some places may require >
- >= “greater than Some places may require >= or equal to”
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
Some XPath functions
- XPath contains a number of functions on node sets, numbers, and strings;
- here are a few of them:
- count(elem) counts the number of selected elements
- Example: //chapter[count(section)=1] selects chapters with exactly two section children
- name() returns the name of the element
- Example: //*[name()='section'] is the same as //section
- starts-with(arg1, arg2) tests if arg1 starts with arg2
- Example: //*[starts-with(name(), 'sec']
- contains(arg1, arg2) tests if arg1 contains arg2
- Example: //*[contains(name(), 'ect']
XSLT
(eXtensible Stylesheet Language Transformations)
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:tei="http://www.tei-c.org/ns/1.0"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
version="2.0">
<xsl:output method="html"/>
<xsl:template match="tei:TEI">
<html>
<head>
<meta charset="UTF-8"/>
</head>
<body>
<xsl:apply-templates/>
</body>
</html>
</xsl:template>
data:image/s3,"s3://crabby-images/13a3d/13a3d2a0621a6508906d98c012e2c007c76784cc" alt=""
Transformation
<?xml version="1.0" encoding="utf-8"?> <poem> <head>Chapter 7th</head> <author></author> <div type="poem"> <l>It was on a dreary night of Novembe</l> </poem> |
<html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta/> </head> <body> <h1>Untitled</h1> <p>It was on a dreary night of Novembe</p> </body> </html> |
---|
XML
HTML
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
XML | HTML |
---|---|
<TEI> ... <body> <text> <body> </body> </text> </body> </TEI> |
<html> <head> <head> <body> </body> </html> |
xslt
XSL (eXtensible Stylesheet Language) is a styling language for XML. XSLT stands for XSL Transformations.
data:image/s3,"s3://crabby-images/cfb84/cfb84470794adead3f2a80d786d6bf952bcc4dcc" alt=""
Make a new file: File >
XML declaration
data:image/s3,"s3://crabby-images/ab5f9/ab5f9c72df2969a3dc1fdab3d0d7f932d198fbd4" alt=""
Namespace
data:image/s3,"s3://crabby-images/ab5f9/ab5f9c72df2969a3dc1fdab3d0d7f932d198fbd4" alt=""
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
- XML Namespaces provide a method to avoid element name conflicts.
- XML standard way to use two or more XML vocabularies
- In XSLT there are at least two vocabularies (can be more): XSLT and HTML
Namespaces
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
TEI Namespace
data:image/s3,"s3://crabby-images/e4175/e417540e6eea30e82b4462e26e845231eb599de0" alt=""
xmlns:tei="http://www.tei-c.org/ns/1.0"
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
<xsl:output/>
<xsl:output method=" HTML ">
The <xsl:output> element defines the format of the output document.
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
<xsl:template>
The <xsl:template> element is used to build templates.
A template (definition from Wiktionary) is
a generic model or pattern from which other objects are based or derived
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
<xsl:template>
The <xsl:template> element is used to build templates.
The match attribute is used to associate a template with an XML element. The match attribute can also be used to define a template for the entire XML document. The value of the match attribute is an XPath expression (i.e. match="/" defines the whole document).
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
<xsl:template match="node">
[materials to include before node's content]
<xsl:apply-templates/>
[materials to include after node's content]
</xsl:template>
<xsl:template>
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
<xsl:apply-templates>
- Indicates where to put the node matched by the template
- In
process the node an allits content (other nodes included!)
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
Our first instruction:
Transform the element root <TEI> into <html>
Let's learn by doing it
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
Add to your xslt the template that matches with your root element:
<xsl:template match="tei:TEI">
<html>
<head>
<meta charset="UTF-8"/>
</head>
<body>
<xsl:apply-templates/>
</body>
</html>
</xsl:template>
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
Add to your xslt the template that matches with the first element:
Text
<xsl:template match="/">
<xsl:apply-templates select="/tei:TEI/tei:teiHeader" />
</xsl:template>
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
This to create a HTML that matches with the tei:Header
Text
<xsl:template match="/">
<xsl:apply-templates select="/tei:TEI/tei:teiHeader" />
</xsl:template>
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
Add the <title> element to the template
Text
<head>
<title><xsl:value-of select=".//tei:title" /></title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
</head>
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
Text
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
<xsl:template match="//tei:head">
<h2>
<ins><xsl:apply-templates/></ins>
</h2>
</xsl:template>
HTML tags
The <h1> to <h6> tags are used to define HTML headings.
<ins>...</ins> underline the text:
Add some more instructions:
The element XML <head> into the element HTML <h2>
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
Add some more instructions:
The element XML <p> into the element HTML <p>
<xsl:template match="//tei:p">
<p><xsl:apply-templates/></p>
</xsl:template>
HTML
The <p> in TEI is the same in HTML <p> > paragraph
You can also use <br/> stands for line break in HTML
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
Use your XSLT!
Go down and check how to do it in command line, oXygen and Atom
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
Use your XSLT!
Command line
Install (sudo) npm install -g xslt3
(RUN)
xslt3 -xsl:[name.xsl] -s:[name].xml > output2.html
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
Create a scenario with your XSLT!
data:image/s3,"s3://crabby-images/de00a/de00ae0d6513bf356065f3a56da99dcc2ad893ae" alt=""
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
Create a scenario with your XSLT!
data:image/s3,"s3://crabby-images/39ab5/39ab594d309191ba9d94a8f843b2f194e1a3bf00" alt=""
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
Create a scenario with your XSLT!
data:image/s3,"s3://crabby-images/c2ccf/c2ccf4ae280101fed449d3de571065cc1c65a97c" alt=""
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
Create a scenario with your XSLT!
data:image/s3,"s3://crabby-images/17756/177564600009930f6e6fcedaadedb66c1abcd4ac" alt=""
data:image/s3,"s3://crabby-images/85728/8572897f121a0c11bb50569df36f651fbaefcdc7" alt=""
Create a scenario with your XSLT!
file XML
file XSLT
SAXON VERSION 9
(software)
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
Create a scenario with your XSLT!
data:image/s3,"s3://crabby-images/533b5/533b5a980bbe53672f65363c4ede96451aa42e73" alt=""
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
Create a scenario with your XSLT!
data:image/s3,"s3://crabby-images/f4a3f/f4a3f0f9da393dcb6c0976da9828c99c08104a7e" alt=""
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
HOW TO USE ATOM
data:image/s3,"s3://crabby-images/90516/90516e48903c4ce5996e2c191e33d31b413dc344" alt=""
CTRL + SHIFT + P
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
HOW TO USE ATOM
data:image/s3,"s3://crabby-images/a47c5/a47c503a382d96dfeb04cb0c14cee301f6dbba7b" alt=""
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
HOW TO USE ATOM
data:image/s3,"s3://crabby-images/74e0e/74e0e23c0ef5c537c234d59345c2a45ee4e555cd" alt=""
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
<xsl:value-of select="node"/>
The <xsl:value-of> element can be used to extract the value of an XML element and add it to the output stream of the transformation:
<img width="600" height="600">
<xsl:attribute name="src">
<xsl:value-of select="//tei:facsimile/tei:graphic/@url"/>
</xsl:attribute>
</img>
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
The <xsl:if> element contains a test attribute and a template. If the test evaluates to true, the template is processed. In this it is similar to an if statement in other languages. To achieve the functionality of an if-then-else statement, however, use the <xsl:choose> element with one <xsl:when> and one <xsl:otherwise> children.
<xsl:if test="expression">
...some output if the expression is true...
</xsl:if>
<xsl:if>
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
<xsl:template match="//tei:hi">
<xsl:choose>
<xsl:when test="@rend='u'">
<u>
<xsl:apply-templates/>
</u>
</xsl:when>
<xsl:otherwise>
<sup>
<xsl:apply-templates/>
</sup>
</xsl:otherwise>
</xsl:choose>
</xsl:template>
<xsl:choose>
<xsl:choose> tag specifies a multiple conditional tests against the content of nodes in conjunction with the <xsl:otherwise> and <xsl:when> elements.
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
<xsl:variable
name="name"
select="expression">
<!-- Content:template -->
</xsl:variable>
<xsl:variable>
<xsl:copy-of select="$variable" />
The <xsl:variable> element declares a global or local variable in a stylesheet and gives it a value. Because XSLT permits no side-effects, once the value of the variable has been established, it remains the same until the variable goes out of scope
data:image/s3,"s3://crabby-images/dd871/dd871aaad15bf72dfde742883deff071903333d3" alt=""
<xsl:include>
<xsl:include>
The <xsl:include> element merges the contents of one stylesheet with another. Unlike the case of <xsl:import>, the contents of an included stylesheet have exactly the same precedence as the contents of the including stylesheet.
Text
W3SCHOOLS
XPATH - https://www.w3schools.com/xml/xpath_intro.asp
XSLT - https://www.w3schools.com/xml/xsl_intro.asp
Mozilla - MDM
https://developer.mozilla.org/en-US/docs/Web/XSLT
Resources:
data:image/s3,"s3://crabby-images/0604f/0604f1839ba8ec0034ede53e347f0500d22dca04" alt=""
Many thanks!
Contacts: @tizmancinelli
tiziana.mancinelli@unive.it
Copy of XPATH - XSLT Bologna, May 2021
By Tiziana Mancinelli
Copy of XPATH - XSLT Bologna, May 2021
- 583