Мне нужно выполнить замену строк запросов из всех атрибутов в RSS-канале MRSS в стиле регулярных выражений, урезав их до URL. Я попробовал несколько вещей здесь, используя подсказки отсюда: Функция замены XSLT не найдена , но безрезультатно
<?xml version="1.0" encoding="utf-8"?> <rss xmlns:atom="http://www.w3.org/2005/Atom" xmlns:media="http://search.yahoo.com/mrss/" version="2.0"> <channel> <atom:link href="http://www.videojug.com/user/metacafefamilyandeducation/subscriptions.mrss" type="application/rss+xml" rel="self" /> <title>How to and instructional videos from Videojug.com</title> <description>Award-winning Videojug.com has over 50k professionally-made instructional videos.</description> <link>http://www.videojug.com</link> <item> <title>How To Calculate Median</title> <media:content url="http://direct.someurl.com/54/543178dd-11a7-4b8d-764c-ff0008cd2e95/how-to-calculate-median__VJ480PENG.mp4?somequerystring" type="video/mp4" bitrate="1200" height="848" duration="169" width="480"> <media:title>How To Calculate Median</media:title> .. </media:content> </item>
любые предложения действительно полезны
Если вы используете XSLT 2.0, вы можете использовать tokenize():
tokenize()
<xsl:template match="media:content"> <xsl:value-of select="tokenize(@url,'\?')[1]"/> </xsl:template>
Вот еще один пример изменения только атрибута url media:content:
url
media:content
<xsl:template match="media:content"> <media:content url="{tokenize(@url,'\?')[1]}"> <xsl:copy-of select="@*[not(name()='url')]"/> <xsl:apply-templates/> </media:content> </xsl:template>
EDIT
Чтобы обработать все url атрибутов в вашем экземпляре и оставить все остальное без изменений, используйте преобразование идентичности и переопределите его только шаблоном для @url.
@url
Вот модифицированная версия вашего примера XML. Я добавил два атрибута в description для тестирования. Атрибут attr следует оставить без изменений, а атрибут url должен быть обработан.
description
attr
XML
<rss xmlns:atom="http://www.w3.org/2005/Atom" xmlns:media="http://search.yahoo.com/mrss/" version="2.0"> <channel> <atom:link href="http://www.videojug.com/user/metacafefamilyandeducation/subscriptions.mrss" type="application/rss+xml" rel="self"/> <title>How to and instructional videos from Videojug.com</title> <!-- added some attributes for testing --> <description attr="don't delete me!" url="http://www.test.com/foo?anotherquerystring">Award-winning Videojug.com has over 50k professionally-made instructional videos.</description> <link>http://www.videojug.com</link> <item> <title>How To Calculate Median</title> <media:content url="http://direct.someurl.com/54/543178dd-11a7-4b8d-764c-ff0008cd2e95/how-to-calculate-median__VJ480PENG.mp4?somequerystring" type="video/mp4" bitrate="1200" height="848" duration="169" width="480"> <media:title>How To Calculate Median</media:title> .. </media:content> </item> </channel> </rss>
XSLT
<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:media="http://search.yahoo.com/mrss/"> <xsl:output indent="yes"/> <xsl:strip-space elements="*"/> <!--Identity Transform--> <xsl:template match="node()|@*"> <xsl:copy> <xsl:apply-templates select="node()|@*"/> </xsl:copy> </xsl:template> <xsl:template match="@url"> <xsl:attribute name="url"> <xsl:value-of select="tokenize(.,'\?')[1]"/> </xsl:attribute> </xsl:template> </xsl:stylesheet>
ВЫХОД (с использованием Saxon 9.3.0.5)
<rss xmlns:atom="http://www.w3.org/2005/Atom" xmlns:media="http://search.yahoo.com/mrss/" version="2.0"> <channel> <atom:link href="http://www.videojug.com/user/metacafefamilyandeducation/subscriptions.mrss" type="application/rss+xml" rel="self"/> <title>How to and instructional videos from Videojug.com</title> <!-- added some attributes for testing --><description attr="don't delete me!" url="http://www.test.com/foo">Award-winning Videojug.com has over 50k professionally-made instructional videos.</description> <link>http://www.videojug.com</link> <item> <title>How To Calculate Median</title> <media:content url="http://direct.someurl.com/54/543178dd-11a7-4b8d-764c-ff0008cd2e95/how-to-calculate-median__VJ480PENG.mp4" type="video/mp4" bitrate="1200" height="848" duration="169" width="480"> <media:title>How To Calculate Median</media:title> .. </media:content> </item> </channel> </rss>
Обработка строк в XSLT, как правило, намного проще с XSLT 2.0, но в этом случае это выглядит достаточно просто, чтобы выполнить требование, используя функцию substring-before (), которая присутствует с XSLT 1.0.