如何解决XSLT-从出现多次的元素中删除空格和连字符
我正在完成付款集成转换。一个XML付款文件可以包含多个付款。因此,将有一个以上的IBAN()实例。我需要XSLT删除的一个或多个实例中的所有空格和连字符。下面的XML。我已经用尽了所有选择。至于这个项目,这是我唯一需要回答的艺术。在下面的XML示例中,有两个IBAN实例。我已经尝试了for-each,在变量中存储和删除字符(最终在两个元素中都包含concat值)...任何帮助都将非常有用。这是示例数据,不是实际的付款数据。
<?xml version="1.0" encoding="utf-8"?> <Document xmlns="urn:iso:std:iso:20022:tech:xsd:pain.001.001.03" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> <CstmrCdtTrfInitn>
<GrpHdr>
<Msgid>FILEREFT2</Msgid>
<CreDtTm>2016-07-05T14:20:07</CreDtTm>
<NbOfTxs>2</NbOfTxs>
<CtrlSum>251000.50</CtrlSum>
<InitgPty>
<Nm>Test Client</Nm>
<Id>
<OrgId>
<Othr>
<Id>CLIENT ID</Id>
</Othr>
</OrgId>
</Id>
</InitgPty>
</GrpHdr>
<PmtInf>
<PmtInfId>BATCHREF</PmtInfId>
<PmtMtd>TRF</PmtMtd>
<NbOfTxs>1</NbOfTxs>
<CtrlSum>251000.50</CtrlSum>
<PmtTpInf>
<SvcLvl>
<Cd>URGP</Cd>
</SvcLvl>
</PmtTpInf>
<ReqdExctnDt>2016-07-05</ReqdExctnDt>
<Dbtr>
<Nm>This Is My Debtor</Nm>
<PstlAdr>
<PstCd>ABCD1XXX</PstCd>
<TwnNm>London</TwnNm>
<CtrySubDvsn>Regent's Place</CtrySubDvsn>
<Ctry>GB</Ctry>
<AdrLine>10 A Street</AdrLine>
</PstlAdr>
</Dbtr>
<DbtrAcct>
<Id>
<IBAN>GB-29NWBK 601613319268 19</IBAN>
</Id>
<Ccy>GBP</Ccy>
</DbtrAcct>
<DbtrAgt>
<FinInstnId>
<BIC>NWBKGB2L</BIC>
<ClrsysMmbId>
<MmbId>601613</MmbId>
</ClrsysMmbId>
<PstlAdr>
<TwnNm>London</TwnNm>
<Ctry>GB</Ctry>
<AdrLine>London</AdrLine>
</PstlAdr>
</FinInstnId>
</DbtrAgt>
<CdtTrftxInf>
<PmtId>
<InstrId>TRXREFT2</InstrId>
<EndToEndId>TRXREFT2</EndToEndId>
</PmtId>
<Amt>
<Instdamt Ccy="GBP">251000.50</Instdamt>
</Amt>
<ChrgBr>SHAR</ChrgBr>
<CdtrAgt>
<FinInstnId>
<BIC>MIDLGB22XXX</BIC>
<ClrsysMmbId>
<MmbId>404865</MmbId>
</ClrsysMmbId>
<PstlAdr>
<Ctry>GB</Ctry>
</PstlAdr>
</FinInstnId>
</CdtrAgt>
<Cdtr>
<Nm>My Creditor</Nm>
<PstlAdr>
<TwnNm>Leeds</TwnNm>
<Ctry>GB</Ctry>
<AdrLine>Palace Square</AdrLine>
</PstlAdr>
</Cdtr>
<CdtrAcct>
<Id>
<IBAN>GB-32ESSE40486562136016</IBAN>
</Id>
</CdtrAcct>
<RmtInf>
<Ustrd>Free Text- This is a CHAPS payment 12345.</Ustrd>
</RmtInf>
</CdtTrftxInf> <CdtTrftxInf>
<PmtId>
<InstrId>TRXREFT3</InstrId>
<EndToEndId>TRXREFT3</EndToEndId>
</PmtId>
<Amt>
<Instdamt Ccy="GBP">1000.3</Instdamt>
</Amt>
<ChrgBr>SHAR</ChrgBr>
<CdtrAgt>
<FinInstnId>
<BIC>MIDLGB22XXX</BIC>
<ClrsysMmbId>
<MmbId>404865</MmbId>
</ClrsysMmbId>
<PstlAdr>
<Ctry>GB</Ctry>
</PstlAdr>
</FinInstnId>
</CdtrAgt>
<Cdtr>
<Nm>My Creditor</Nm>
<PstlAdr>
<TwnNm>Leeds</TwnNm>
<Ctry>GB</Ctry>
<AdrLine>Spire Apparel</AdrLine>
</PstlAdr>
</Cdtr>
<CdtrAcct>
<Id>
<IBAN>GB32ESSE404865621360 16</IBAN>
</Id>
</CdtrAcct>
<RmtInf>
<Ustrd>Free Text- This is a FASTER payment 12345.</Ustrd>
</RmtInf>
</CdtTrftxInf>
</PmtInf> </CstmrCdtTrfInitn> </Document>
解决方法
不知道您使用的是哪个版本的XSLT,但这应该涵盖所有这些...
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:idk="urn:iso:std:iso:20022:tech:xsd:pain.001.001.03">
<xsl:output indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="idk:IBAN/text()">
<xsl:value-of select="translate(.,'- ','')"/>
</xsl:template>
</xsl:stylesheet>
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。