Is there any XPath expression for String Padding in wso2 ESB?

只谈情不闲聊 提交于 2019-12-02 01:35:32
har07

This can be achieved using XPath 1.0 like so, assuming that "WSO2" will be replaced by dynamic input string in the actual implementation :

substring(concat('WSO2', '%%%%%%%%%%'), 1, 10)

The above XPath basically works by concatenating string of 10 specific for-padding characters to the original input string, and then substring the result to get only the first 10 characters. Found this trick in the following XSL question : XSL left-right justification with Padding

To put this in a more generic formula :

substring(concat('input_string', '%%%%....'), 1, n)
  • input_string : string to which padding operation will applied
  • % : character used for padding, repeated n times
  • n : fixed number of characters expected in the output string

The solution from @har07 is fine if you have a reasonable upper bound on the value of n, but if you don't, you can create a string containing '%' repeated $n times using

XPath 3.0: string-join((1 to $n)!"%")

XPath 2.0: string-join(for $x in 1 to $n return "%", "")
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!