2012-12-02 22 views
3

我正在嘗試編寫一個處理都柏林核心(XML)編目記錄併爲每本書創建芝加哥,APA和MLA版本的引文的XSLT樣式表。除了APA作者之外,我已經將所有的工作都做好了。 APA對作者的風格要求作者的姓氏(完成),逗號,第一首字母(完成),任何其他首字母(我的卡住地點問題)。使用XSLT在字符串/子串中的每個實例後選擇

我現在所擁有的(下面,品嚐DC元素):

<xsl:value-of select="substring-before(dc:creator[1],',')" /><xsl:text>, </xsl:text><xsl:value-of select="substring(substring-after(dc:creator[1],' '),1,1)" /><xsl:for-each select="dc:creator[position()!=1]"><xsl:choose><xsl:when test="position()=last()"><xsl:text>., &amp; </xsl:text></xsl:when><xsl:otherwise>., </xsl:otherwise></xsl:choose><xsl:value-of select="substring-before(.,',')" /><xsl:text>, </xsl:text><xsl:value-of select="substring(substring-after(.,' '),1,1)" /><xsl:if test="position()=last()">.</xsl:if></xsl:for-each> 

對於以下格式的情況下(出什麼目錄使用):

<dc:creator>Friend, Natasha</dc:creator> 

這工作得很好,返回:Friend, N.

<dc:creator>Tolkien, J. R. R.</dc:creator> 

返回:Tolkien, J.

在很多也沒關係的情況下,反而會出現情況下,它確實需要返回作者的中間名首字母(S),像J.R.R. TolkienJ.K. Rowling

因此,我需要能夠返回每個空間後發生的字母,而不僅僅是空間的第一個實例。

任何想法?

回答

3

一,下面是一個簡單的和自然的XSLT 2.0解決方案:

<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" 
xmlns:xs="http://www.w3.org/2001/XMLSchema"> 
<xsl:output omit-xml-declaration="yes" indent="yes"/> 
<xsl:strip-space elements="*"/> 

<xsl:template match="/*/*"> 
    <xsl:value-of separator=", " select= 
    "substring-before(., ',') 
    , for $n in tokenize(substring-after(., ','), '\s')[.] 
     return 
      substring($n, 1,1) 
    "/> 
    <xsl:text>&#xA;</xsl:text> 
</xsl:template> 
</xsl:stylesheet> 

當下面的XML文檔應用這種轉變:

<t xmlns:dc="some:dc"> 
<dc:creator >Friend, Natasha</dc:creator> 

<dc:creator>Tolkien, J. R. R.</dc:creator> 
</t> 

想要的,正確的結果產生:

Friend, N 
Tolkien, J., R., R. 

二,一個XSLT 1.0溶液

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> 
<xsl:output omit-xml-declaration="yes" indent="yes"/> 
<xsl:strip-space elements="*"/> 

<xsl:template match="/*/*/text()"> 
    <xsl:value-of select="substring-before(., ',')"/> 

    <xsl:call-template name="replaceTokenDelims"> 
    <xsl:with-param name="pStr" select= 
    "concat(normalize-space(substring-after(., ',')), ' ')"/> 
    <xsl:with-param name="pToken" select="' '"/> 
    <xsl:with-param name="pReplacement" select="', '"/> 
    </xsl:call-template> 
    <xsl:text>&#xA;</xsl:text> 
</xsl:template> 

<xsl:template name="replaceTokenDelims"> 
    <xsl:param name="pStr"/> 
    <xsl:param name="pToken"/> 
    <xsl:param name="pReplacement"/> 

    <xsl:if test="$pStr"> 
    <xsl:value-of select="$pReplacement"/> 
    <xsl:value-of select= 
     "substring(substring-before($pStr, $pToken), 1, 1)"/> 

    <xsl:call-template name="replaceTokenDelims"> 
     <xsl:with-param name="pStr" 
      select="substring-after($pStr, $pToken)"/> 
     <xsl:with-param name="pToken" select="$pToken"/> 
     <xsl:with-param name="pReplacement" select="$pReplacement"/> 
    </xsl:call-template> 
    </xsl:if> 
</xsl:template> 
</xsl:stylesheet> 

當這種轉化是在同一個XML文檔(以上)應用,再次同樣正確的結果產生

Friend, N 
Tolkien, J., R., R. 
+0

我一直使用1.0自我更熟悉它,但我會檢查一下,謝謝。除了每個之後,回報看起來都很棒,但我會把它拿出來。 – Talia

+0

@Talia:我認爲'','是被要求作爲新的分隔符。如果不是什麼應該是分隔符?我還將提供一個XSLT 1.0解決方案。 –

+0

@Talia,用新增的XSLT 1.0解決方案更新了答案。 –

相關問題