XSL 用插入符号替换空格

Doc*_*jay 3 xslt replace spaces

更新代码:

    <?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
  <xsl:output method="xml" indent="no"/>
  <!-- overwritten by application with actual values -->
  <xsl:param name="calling" select="'SAMPLE_MOD'"/>
  <xsl:param name="called" select="'SERVER1'"/>
  <xsl:param name="date" select="'20051206'"/>
  <xsl:param name="time" select="'115600.000'"/>
  <xsl:param name="PatName" select="attr[@tag='00100010']"/>
  <xsl:template match="/dataset">
     <dataset>
     <xsl:variable name="PerfProcStepDesc" select="attr[@tag='00400254']"/>
     <xsl:variable name="StudyDesc" select="attr[@tag='00081030']"/>
       <xsl:if test="string-length($StudyDesc)=0">
         <xsl:if test="$PerfProcStepDesc">
            <!-- (0008,1030) Study Description -->
           <attr tag="00081030" vr="LO">
             <xsl:value-of select="$PerfProcStepDesc"/>
           </attr>
         </xsl:if>
       </xsl:if>
     </dataset>
     <dataset>
        <xsl:variable name="caret" select="'^'"/>
        <xsl:if test="contains($PatName, ' ')">
            <xsl:value-of select="translate($PatName, ' ','^')"/>
        </xsl:if>   
     </dataset>
  </xsl:template>
</xsl:stylesheet>
Run Code Online (Sandbox Code Playgroud)

变量 'PatName' 可能会出现为 'DOE JOHN',我需要将它转换为 'DOE^JOHN' 名称中也可能有多个空格,所以我希望所有的“空格”都改为插入符号并保留它们名称中的当前位置。

我需要对名称中的逗号做同样的事情。

目前,输出就像它进入时一样,所以我的测试没有按预期工作。

谢谢你看!

编辑#2:

我已经更改了我的代码以应用身份转换(希望我的代码是正确的!)当它处理我的 XSL 样式表时,我还有 XSL 输入和 XSL 输出。

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
  <xsl:output method="xml" indent="no"/>
  <!-- overwritten by application with actual values -->
  <xsl:param name="calling" select="'SAMPLE_MOD'"/>
  <xsl:param name="called" select="'SERVER1'"/>
  <xsl:param name="date" select="'20051206'"/>
  <xsl:param name="time" select="'115600.000'"/>
  <xsl:param name="PatName" select="attr[@tag='00100010']"/>
<!-- IdentityTransform -->
<xsl:template match="/ | @* | node()">
    <xsl:copy>
        <xsl:apply-templates select="@* | node()" />
    </xsl:copy>
</xsl:template>
  <xsl:template match="/dataset">
     <dataset>
     <xsl:variable name="PerfProcStepDesc" select="attr[@tag='00400254']"/>
     <xsl:variable name="StudyDesc" select="attr[@tag='00081030']"/>
       <xsl:if test="string-length($StudyDesc)=0">
         <xsl:if test="$PerfProcStepDesc">
            <!-- (0008,1030) Study Description -->
           <attr tag="00081030" vr="LO">
             <xsl:value-of select="$PerfProcStepDesc"/>
           </attr>
         </xsl:if>
       </xsl:if>
     </dataset>
     <dataset>
        <xsl:variable name="caret" select="'^'"/>
        <xsl:if test="contains($PatName, ' ')">
            <xsl:value-of select="translate($PatName, ' ','^')"/>
        </xsl:if>   
     </dataset>
  </xsl:template>
</xsl:stylesheet>
Run Code Online (Sandbox Code Playgroud)

XSL在此处输入

XSL 输出如下:

<?xml version="1.0" encoding="UTF-8"?>
<dataset/>
Run Code Online (Sandbox Code Playgroud)

在 XSL 输入中,“患者姓名”有“SMPTE PATTERN”,我期待“SMPTE^PATTERN”。

我希望这会有所帮助,我希望我的身份转换器正确。

谢谢大家的时间

Lin*_* CS 5

您可以使用翻译功能。

<xsl:value-of select="translate($PatName, ' ', '^')"/>
Run Code Online (Sandbox Code Playgroud)

如果您想用插入符号替换逗号和空格,请使用以下命令:

<xsl:value-of select="translate($PatName, ' ,', '^^')"/>
Run Code Online (Sandbox Code Playgroud)