如何修复XSLT中的特殊字符 [英] How to fix a special character in XSLT
本文介绍了如何修复XSLT中的特殊字符的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我正在处理下面的XML,其中我需要删除名字中的特殊字符。Andrés)不确定这个角色到底叫什么。如果我按原样处理Firstname,则它在供应商系统中失败
<?xml version="1.0" encoding="UTF-8"?>
<reportentry>
<reportdata>
<id>12345</id>
<firstname>Andrés</firstname>
<lastname>Williams</lastname>
</reportdata>
</reportentry>
我只是简单地尝试了一下正在运行的替换函数,下面是代码。不确定有没有更好的方法来处理它?有什么建议吗?
<xsl:value-of select="replace($string1, 'é', 'e')"/>
完整代码
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:xs="http://www.w3.org/2001/XMLSchema" exclude-result-prefixes="xs" version="2.0">
<xsl:variable name="string1" select="/reportentry/reportdata/firstname"/>
<xsl:variable name="comma" select="','"/>
<xsl:output method="text" omit-xml-declaration="yes"/>
<xsl:template match="/reportentry">
<xsl:value-of select="reportdata/id"/>
<xsl:value-of select="$comma"/>
<xsl:value-of select="replace($string1, 'é', 'e')"/>
<xsl:value-of select="$comma"/>
<xsl:value-of select="reportdata/lastname"/>
</xsl:template>
</xsl:stylesheet>
我预计结果是12345,安德烈斯,威廉姆斯
推荐答案
您可以通过使用normalize-unicode()
将字符串转换为分解的范式(Nfd),然后使用replace()
删除所有"非空格"字符(类别Mn
)来去除大多数变音符号。
因此replace(normalize-unicode(xxx, 'NFD'), 'p{Mn}', '')
未测试。
但最好是对接收应用程序进行现代化处理,以便它可以处理国际名称...
这篇关于如何修复XSLT中的特殊字符的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文