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”。
我希望这会有所帮助,我希望我的身份转换器正确。
谢谢大家的时间
您可以使用翻译功能。
<xsl:value-of select="translate($PatName, ' ', '^')"/>
Run Code Online (Sandbox Code Playgroud)
如果您想用插入符号替换逗号和空格,请使用以下命令:
<xsl:value-of select="translate($PatName, ' ,', '^^')"/>
Run Code Online (Sandbox Code Playgroud)