说来惭愧,一直用 replace 替换,却一直没注意第二个参数可以放函数,也一直没用到。今天在做 excel 下载时发现一直报表名的错误,发现名字超长了,也才发现原来 excel 表名最长好像到31个字符。

想着简单,把中间截取一下替换成 ~ 就可以了。然后发现 replace 不能一次性满足我,虽然用两次可以解决,但是不能忍,于是去 文档 恶补了一下。

函数需要返回一个新的字符串值,该值就是我们需要接收的值。

对应我的需求,现在有一个超长的名字,比如它是:abcdefghijklmnopqrstuvwxyz1234567890,现在需要将其缩短,策略是前20个字符保留,后5个字符保留,中间所有字符替换为 ~,就可以使用上面函数:

使用参数字符串,需要通过关键字符 $ 来获取,平时使用时如果用到过 $ 作为替换字符的话会有注意:

$n 获取第n个获取到的子串,同上面的 p1p2...pn

它可以获取对应的内容,但是不要直接对参数字符串进行修改:

正则匹配了全局内容,所以全局内容被替换为了 ~

replace 返回的结果是 ~,name 被重新赋值为 ~

所以,这种方式不能在参数字符串中直接修改内容。

那么为了得到正确结果,有没有可行的方式呢?

答案是肯定的,对应上面使用函数的例子,可以使用参数字符串进行替换: