在致远项目上遇到了一个需求,需要根据公文文号进行排序,直接使用公文文号字段进行排序达不到效果,故采用自定义函数截取文号中的数字用于排序。
点击计算公式,点击新建,设置好参数和名称
代码如下:
/*此处的param[0]的意思是第一个参数,所以如果有第二个参数的话则是param[1]以此类推*/
String res = param[0];
def parten=/[^0-9]/;
return res.replaceAll(parten,'');
实现效果如下图
但是现在有一个问题,如果跨年了,那么排序还是会乱,因为数字位数对不上,所以需要将代码优化达到位数相同,故需要在截取的数字中间补零。优化后的代码如下:
String res = param[0];
def parten=/[^0-9]/;
def temp=res.replaceAll(parten,'');
def firstStr=temp.substring(0,4);
def lastStr=temp.substring(4);
lastStr=lastStr.padLeft(3,'0');
return firstStr+lastStr;
实现效果为20234→2023004