新增自定义排序工具类
This commit is contained in:
parent
0e8934fe21
commit
18eac06445
178
cloud-common/src/main/java/com/cm/common/utils/SortCodeUtil.java
Normal file
178
cloud-common/src/main/java/com/cm/common/utils/SortCodeUtil.java
Normal file
@ -0,0 +1,178 @@
|
||||
package com.cm.common.utils;
|
||||
|
||||
import org.springframework.security.core.parameters.P;
|
||||
|
||||
/**
|
||||
* When you feel like quitting. Think about why you started
|
||||
* 当你想要放弃的时候,想想当初你为何开始
|
||||
*
|
||||
* @ClassName: SortCodeUtil
|
||||
* @Description: 排序编码工具
|
||||
* @Author: WangGeng
|
||||
* @Date: 2020/1/14 10:21 下午
|
||||
* @Version: 1.0
|
||||
**/
|
||||
public class SortCodeUtil {
|
||||
|
||||
/**
|
||||
* 获取排序Code
|
||||
*
|
||||
* @param lastCode 上一个编码,第一个null
|
||||
* @param separator 分隔符 默认"-"
|
||||
* @param sectionLength 片段长度 默认长度3
|
||||
* @return
|
||||
*/
|
||||
public static String getSortCode(String lastCode, String separator, int sectionLength) {
|
||||
separator = separator == null || separator.isEmpty() ? "-" : separator;
|
||||
sectionLength = sectionLength <= 0 ? 3 : sectionLength;
|
||||
String carryFlag = String.format("%0" + sectionLength + "d", 0);
|
||||
if (lastCode == null || lastCode.isEmpty()) {
|
||||
return carryFlag;
|
||||
}
|
||||
// 获取分段数组
|
||||
String[] sectionArray = lastCode.split(separator);
|
||||
boolean hasCarry = true;
|
||||
String resultSortCode = "";
|
||||
for (int i = sectionArray.length - 1; i >= 0; i--) {
|
||||
String section = sectionArray[i];
|
||||
if (hasCarry) {
|
||||
String nextCode = nextCode(section, sectionLength);
|
||||
if (resultSortCode.isEmpty()) {
|
||||
resultSortCode = nextCode;
|
||||
} else {
|
||||
resultSortCode = nextCode + separator + resultSortCode;
|
||||
}
|
||||
if (carryFlag.equals(nextCode)) {
|
||||
hasCarry = true;
|
||||
continue;
|
||||
}
|
||||
hasCarry = false;
|
||||
} else {
|
||||
resultSortCode = section + separator + resultSortCode;
|
||||
}
|
||||
}
|
||||
return resultSortCode;
|
||||
}
|
||||
|
||||
/**
|
||||
* 下一个编码,编码大小为 36^sectionLength
|
||||
*
|
||||
* @param code 编码
|
||||
* @param sectionLength 长度
|
||||
* @return
|
||||
*/
|
||||
public static String nextCode(String code, int sectionLength) {
|
||||
if (code == null || code.isEmpty()) {
|
||||
return String.format("%0" + sectionLength + "d", 0);
|
||||
}
|
||||
code = code.toUpperCase();
|
||||
char[] charArray = code.toCharArray();
|
||||
boolean hasCarry = true;
|
||||
String resultCode = "";
|
||||
for (int i = charArray.length - 1; i >= 0; i--) {
|
||||
char currentChar = charArray[i];
|
||||
if (hasCarry) {
|
||||
char nextChar = nextChar(currentChar);
|
||||
resultCode = nextChar + resultCode;
|
||||
if ('0' == nextChar) {
|
||||
hasCarry = true;
|
||||
continue;
|
||||
}
|
||||
hasCarry = false;
|
||||
} else {
|
||||
// 没有发生进位直接相加
|
||||
resultCode = currentChar + resultCode;
|
||||
}
|
||||
}
|
||||
return resultCode;
|
||||
}
|
||||
|
||||
/**
|
||||
* 下一个字节
|
||||
*
|
||||
* @param currentChar
|
||||
* @return
|
||||
*/
|
||||
public static char nextChar(char currentChar) {
|
||||
char nextChar = '0';
|
||||
if ('0' == currentChar) {
|
||||
nextChar = '1';
|
||||
} else if ('1' == currentChar) {
|
||||
nextChar = '2';
|
||||
} else if ('2' == currentChar) {
|
||||
nextChar = '3';
|
||||
} else if ('3' == currentChar) {
|
||||
nextChar = '4';
|
||||
} else if ('4' == currentChar) {
|
||||
nextChar = '5';
|
||||
} else if ('5' == currentChar) {
|
||||
nextChar = '6';
|
||||
} else if ('6' == currentChar) {
|
||||
nextChar = '7';
|
||||
} else if ('7' == currentChar) {
|
||||
nextChar = '8';
|
||||
} else if ('8' == currentChar) {
|
||||
nextChar = '9';
|
||||
} else if ('9' == currentChar) {
|
||||
nextChar = 'A';
|
||||
} else if ('A' == currentChar) {
|
||||
nextChar = 'B';
|
||||
} else if ('B' == currentChar) {
|
||||
nextChar = 'C';
|
||||
} else if ('C' == currentChar) {
|
||||
nextChar = 'D';
|
||||
} else if ('D' == currentChar) {
|
||||
nextChar = 'E';
|
||||
} else if ('E' == currentChar) {
|
||||
nextChar = 'F';
|
||||
} else if ('F' == currentChar) {
|
||||
nextChar = 'G';
|
||||
} else if ('G' == currentChar) {
|
||||
nextChar = 'H';
|
||||
} else if ('H' == currentChar) {
|
||||
nextChar = 'I';
|
||||
} else if ('I' == currentChar) {
|
||||
nextChar = 'J';
|
||||
} else if ('J' == currentChar) {
|
||||
nextChar = 'K';
|
||||
} else if ('K' == currentChar) {
|
||||
nextChar = 'L';
|
||||
} else if ('L' == currentChar) {
|
||||
nextChar = 'M';
|
||||
} else if ('M' == currentChar) {
|
||||
nextChar = 'N';
|
||||
} else if ('N' == currentChar) {
|
||||
nextChar = 'O';
|
||||
} else if ('O' == currentChar) {
|
||||
nextChar = 'P';
|
||||
} else if ('P' == currentChar) {
|
||||
nextChar = 'Q';
|
||||
} else if ('Q' == currentChar) {
|
||||
nextChar = 'R';
|
||||
} else if ('R' == currentChar) {
|
||||
nextChar = 'S';
|
||||
} else if ('S' == currentChar) {
|
||||
nextChar = 'T';
|
||||
} else if ('T' == currentChar) {
|
||||
nextChar = 'U';
|
||||
} else if ('U' == currentChar) {
|
||||
nextChar = 'V';
|
||||
} else if ('V' == currentChar) {
|
||||
nextChar = 'W';
|
||||
} else if ('W' == currentChar) {
|
||||
nextChar = 'X';
|
||||
} else if ('X' == currentChar) {
|
||||
nextChar = 'Y';
|
||||
} else if ('Y' == currentChar) {
|
||||
nextChar = 'Z';
|
||||
}
|
||||
return nextChar;
|
||||
}
|
||||
|
||||
public static void main(String[] args) {
|
||||
String str = "ZZ0-ZZZ-ZZZ-0ZZ";
|
||||
System.out.println(getSortCode(str, "-", 3));
|
||||
}
|
||||
|
||||
|
||||
}
|
Loading…
Reference in New Issue
Block a user