freemarker字符串替换操作

<#if item.userIP!="">
<#assign text=item.userIP>
     ${text ?replace((text ?substring(text?index_of(".")+1,text?index_of(".")+2)),"*")}

Freemarker操作字符串

点击打开链接

1、substring(start,end)从一个字符串中截取子串 start:截取子串开始的索引,start必须大于等于0,小于等于end end: 截取子串的长度,end必须大于等于0,小于等于字符串长度,如果省略该参数,默认为字符串长度。 例子: ${‘str’?substring(0)}à结果为str ${‘str’?substring(1)}à结果为tr ${‘str’?substring(2)}à结果为r ${‘str’?substring(3)}à结果为 ${‘str’?substring(0,0)}à结果为 ${‘str’?substring(0,1)}à结果为s ${‘str’?substring(0,2)}à结果为st ${‘str’?substring(0,3)}à结果为str

2、cap_first 将字符串中的第一个单词的首字母变为大写。 ${‘str’?cap_first}à结果为Str 3、uncap_first将字符串中的第一个单词的首字母变为小写。 ${‘Str’?cap_first}à结果为str 4、 capitalize将字符串中的所有单词的首字母变为大写 ${‘str’? capitalize}à结果为STR

5、 date,time,datetime将字符串转换为日期 例如: <#assign date1=”2009-10-12”?date(“yyyy-MM-dd”)> <#assign date2=”9:28:20”?time(“HH:mm:ss”)> <#assign date3=” 2009-10-12 9:28:20”?time(“HH:mm:ss”)> ${date1}à结果为2009-10-12 ${date2}à结果为9:28:20 ${date3}à结果为2009-10-12 9:28:20 注意:如果指定的字符串格式不正确将引发错误。

6、ends_with 判断某个字符串是否由某个子串结尾,返回布尔值。 ${“string”?ends_with(“ing”)?string} 返回结果为true 注意:布尔值必须转换为字符串才能输出

7、html 用于将字符串中的<、>、&和“替换为对应得<>":&

8、index_of(substring,start)在字符串中查找某个子串,返回找到子串的第一个字符的索引,如果没有找到子串,则返回-1。 Start参数用于指定从字符串的那个索引处开始搜索,start为数字值。 如果start大于字符串长度,则start取值等于字符串长度,如果start小于0, 则start取值为0。 ${“string”?index_of(“in”) à结果为3 ${“string”?index_of(“ab”) à结果为-1

9、length返回字符串的长度 ${“string”?length}à结果为6

10、lower_case将字符串转为小写 ${“STRING”?lower_case}à结果为string

11、upper_case将字符串转为大写 ${“string”?upper_case}à结果为STRING

12、contains 判断字符中是否包含某个子串。返回布尔值 ${“string”?contains(“ing”)?string} à结果为true 注意:布尔值必须转换为字符串才能输出

13、number将字符串转换为数字 ${“111.11”?number}à结果为111.11

14、replace用于将字符串中的一部分从左到右替换为另外的字符串。 ${“strabg”?replace(“ab”,”in”)} à结果为string

15、split使用指定的分隔符将一个字符串拆分为一组字符串

<#list “This|is|split”?split(“|”) as s> ${s} 结果为: This is split

16、 trim 删除字符串首尾空格 ${“ String ”?trim} à结果为String



Freemaker Replace函数的正则表达式运用


replace(param1,param2,param3)

param1 正则表达式(字符串);param2 将匹配的字符替换成指定字符;param3 模式

param3 参数如下

模式 i r m s c f
replace 支持 支持 只和r 组合 只和r 组合 只和r 组合 支持



模式解释:

i: Case insensitive: 忽略大小写

f: 只替换第一个出现被替换字符串的字符串

r: 要找到的子字符串是一个正则表达式.标准正则表达式(http://docs.oracle.com/javase/7/docs/api/java/util/regex/Pattern.html )

m: 正则表达式的多行模式。在多行模式下的表达式^和$匹配之前或之后,分别行终结者或结束的字符串。默认情况下,这些表达式只匹配整个字符串的开始和结束部分。请注意,^和$不匹配换行字符本身。

s:为正则表达式启用dot-all模式(与Perl singe-line模式相同)。在dot-all模式下,表达式。匹配任何字符,包括行终止符。默认情况下,此表达式不匹配行终止符

c: 在正则表达式中允许空格和注释。




你可能感兴趣的:(freemarker字符串替换操作)