package com.nq.utils;
|
|
import cn.hutool.core.text.StrFormatter;
|
import org.apache.commons.lang3.StringUtils;
|
|
import java.io.UnsupportedEncodingException;
|
import java.util.*;
|
import java.util.regex.Matcher;
|
import java.util.regex.Pattern;
|
|
public class StringUtil extends StringUtils {
|
/**
|
* unicode編碼轉換為漢字
|
* @param unicodeStr 待轉化的編碼
|
* @return 返迴轉化后的漢子
|
*/
|
public static String UnicodeToCN(String unicodeStr) {
|
Pattern pattern = Pattern.compile("(\\\\u(\\p{XDigit}{4}))");
|
Matcher matcher = pattern.matcher(unicodeStr);
|
char ch;
|
while (matcher.find()) {
|
//group
|
String group = matcher.group(2);
|
//ch:'李四'
|
ch = (char) Integer.parseInt(group, 16);
|
//group1
|
String group1 = matcher.group(1);
|
unicodeStr = unicodeStr.replace(group1, ch + "");
|
}
|
|
return unicodeStr.replace("\\", "").trim();
|
}
|
|
/**
|
* 漢字轉化為Unicode編碼
|
* @param CN 待轉化的中文
|
* @return 返迴轉化之後的unicode編碼
|
*/
|
public static String CNToUnicode(String CN) {
|
|
try {
|
StringBuffer out = new StringBuffer("");
|
//直接獲取字符串的unicode二進制
|
byte[] bytes = CN.getBytes("unicode");
|
//然後將其byte轉換成對應的16進製表示即可
|
for (int i = 0; i < bytes.length - 1; i += 2) {
|
out.append("\\u");
|
String str = Integer.toHexString(bytes[i + 1] & 0xff);
|
for (int j = str.length(); j < 2; j++) {
|
out.append("0");
|
}
|
String str1 = Integer.toHexString(bytes[i] & 0xff);
|
out.append(str1);
|
out.append(str);
|
}
|
return out.toString();
|
} catch (UnsupportedEncodingException e) {
|
e.printStackTrace();
|
return null;
|
}
|
}
|
|
public static String delHTMLTag(String htmlStr){
|
String regEx_script="<script[^>]*?>[\\s\\S]*?<\\/script>"; //定義script的正則表達式
|
String regEx_style="<style[^>]*?>[\\s\\S]*?<\\/style>"; //定義style的正則表達式
|
String regEx_html="<[^>]+>"; //定義HTML標籤的正則表達式
|
|
Pattern p_script=Pattern.compile(regEx_script,Pattern.CASE_INSENSITIVE);
|
Matcher m_script=p_script.matcher(htmlStr);
|
htmlStr=m_script.replaceAll(""); //過濾script標籤
|
|
Pattern p_style=Pattern.compile(regEx_style,Pattern.CASE_INSENSITIVE);
|
Matcher m_style=p_style.matcher(htmlStr);
|
htmlStr=m_style.replaceAll(""); //過濾style標籤
|
|
Pattern p_html=Pattern.compile(regEx_html,Pattern.CASE_INSENSITIVE);
|
Matcher m_html=p_html.matcher(htmlStr);
|
htmlStr=m_html.replaceAll(""); //過濾html標籤
|
|
return htmlStr.trim(); //返迴文本字符串
|
}
|
|
/** 空字符串 */
|
private static final String NULLSTR = "";
|
|
/** 下划线 */
|
private static final char SEPARATOR = '_';
|
|
/**
|
* 获取参数不为空值
|
*
|
* @param value defaultValue 要判断的value
|
* @return value 返回值
|
*/
|
public static <T> T nvl(T value, T defaultValue)
|
{
|
return value != null ? value : defaultValue;
|
}
|
|
/**
|
* * 判断一个Collection是否为空, 包含List,Set,Queue
|
*
|
* @param coll 要判断的Collection
|
* @return true:为空 false:非空
|
*/
|
public static boolean isEmpty(Collection<?> coll)
|
{
|
return isNull(coll) || coll.isEmpty();
|
}
|
|
/**
|
* * 判断一个Collection是否非空,包含List,Set,Queue
|
*
|
* @param coll 要判断的Collection
|
* @return true:非空 false:空
|
*/
|
public static boolean isNotEmpty(Collection<?> coll)
|
{
|
return !isEmpty(coll);
|
}
|
|
/**
|
* * 判断一个对象数组是否为空
|
*
|
* @param objects 要判断的对象数组
|
** @return true:为空 false:非空
|
*/
|
public static boolean isEmpty(Object[] objects)
|
{
|
return isNull(objects) || (objects.length == 0);
|
}
|
|
/**
|
* * 判断一个对象数组是否非空
|
*
|
* @param objects 要判断的对象数组
|
* @return true:非空 false:空
|
*/
|
public static boolean isNotEmpty(Object[] objects)
|
{
|
return !isEmpty(objects);
|
}
|
|
/**
|
* * 判断一个Map是否为空
|
*
|
* @param map 要判断的Map
|
* @return true:为空 false:非空
|
*/
|
public static boolean isEmpty(Map<?, ?> map)
|
{
|
return isNull(map) || map.isEmpty();
|
}
|
|
/**
|
* * 判断一个Map是否为空
|
*
|
* @param map 要判断的Map
|
* @return true:非空 false:空
|
*/
|
public static boolean isNotEmpty(Map<?, ?> map)
|
{
|
return !isEmpty(map);
|
}
|
|
/**
|
* * 判断一个字符串是否为空串
|
*
|
* @param str String
|
* @return true:为空 false:非空
|
*/
|
public static boolean isEmpty(String str)
|
{
|
return isNull(str) || NULLSTR.equals(str.trim());
|
}
|
|
/**
|
* * 判断一个字符串是否为非空串
|
*
|
* @param str String
|
* @return true:非空串 false:空串
|
*/
|
public static boolean isNotEmpty(String str)
|
{
|
return !isEmpty(str);
|
}
|
|
/**
|
* * 判断一个对象是否为空
|
*
|
* @param object Object
|
* @return true:为空 false:非空
|
*/
|
public static boolean isNull(Object object)
|
{
|
return object == null;
|
}
|
|
/**
|
* * 判断一个对象是否非空
|
*
|
* @param object Object
|
* @return true:非空 false:空
|
*/
|
public static boolean isNotNull(Object object)
|
{
|
return !isNull(object);
|
}
|
|
/**
|
* * 判断一个对象是否是数组类型(Java基本型别的数组)
|
*
|
* @param object 对象
|
* @return true:是数组 false:不是数组
|
*/
|
public static boolean isArray(Object object)
|
{
|
return isNotNull(object) && object.getClass().isArray();
|
}
|
|
/**
|
* 去空格
|
*/
|
public static String trim(String str)
|
{
|
return (str == null ? "" : str.trim());
|
}
|
|
/**
|
* 截取字符串
|
*
|
* @param str 字符串
|
* @param start 开始
|
* @return 结果
|
*/
|
public static String substring(final String str, int start)
|
{
|
if (str == null)
|
{
|
return NULLSTR;
|
}
|
|
if (start < 0)
|
{
|
start = str.length() + start;
|
}
|
|
if (start < 0)
|
{
|
start = 0;
|
}
|
if (start > str.length())
|
{
|
return NULLSTR;
|
}
|
|
return str.substring(start);
|
}
|
|
/**
|
* 截取字符串
|
*
|
* @param str 字符串
|
* @param start 开始
|
* @param end 结束
|
* @return 结果
|
*/
|
public static String substring(final String str, int start, int end)
|
{
|
if (str == null)
|
{
|
return NULLSTR;
|
}
|
|
if (end < 0)
|
{
|
end = str.length() + end;
|
}
|
if (start < 0)
|
{
|
start = str.length() + start;
|
}
|
|
if (end > str.length())
|
{
|
end = str.length();
|
}
|
|
if (start > end)
|
{
|
return NULLSTR;
|
}
|
|
if (start < 0)
|
{
|
start = 0;
|
}
|
if (end < 0)
|
{
|
end = 0;
|
}
|
|
return str.substring(start, end);
|
}
|
|
/**
|
* 格式化文本, {} 表示占位符<br>
|
* 此方法只是简单将占位符 {} 按照顺序替换为参数<br>
|
* 如果想输出 {} 使用 \\转义 { 即可,如果想输出 {} 之前的 \ 使用双转义符 \\\\ 即可<br>
|
* 例:<br>
|
* 通常使用:format("this is {} for {}", "a", "b") -> this is a for b<br>
|
* 转义{}: format("this is \\{} for {}", "a", "b") -> this is \{} for a<br>
|
* 转义\: format("this is \\\\{} for {}", "a", "b") -> this is \a for b<br>
|
*
|
* @param template 文本模板,被替换的部分用 {} 表示
|
* @param params 参数值
|
* @return 格式化后的文本
|
*/
|
public static String format(String template, Object... params)
|
{
|
if (isEmpty(params) || isEmpty(template))
|
{
|
return template;
|
}
|
return StrFormatter.format(template, params);
|
}
|
|
/**
|
* 字符串转set
|
*
|
* @param str 字符串
|
* @param sep 分隔符
|
* @return set集合
|
*/
|
public static final Set<String> str2Set(String str, String sep)
|
{
|
return new HashSet<String>(str2List(str, sep, true, false));
|
}
|
|
/**
|
* 字符串转list
|
*
|
* @param str 字符串
|
* @param sep 分隔符
|
* @param filterBlank 过滤纯空白
|
* @param trim 去掉首尾空白
|
* @return list集合
|
*/
|
public static final List<String> str2List(String str, String sep, boolean filterBlank, boolean trim)
|
{
|
List<String> list = new ArrayList<>();
|
if (StringUtils.isEmpty(str))
|
{
|
return list;
|
}
|
|
// 过滤空白字符串
|
if (filterBlank && StringUtils.isBlank(str))
|
{
|
return list;
|
}
|
String[] split = str.split(sep);
|
for (String string : split)
|
{
|
if (filterBlank && StringUtils.isBlank(string))
|
{
|
continue;
|
}
|
if (trim)
|
{
|
string = string.trim();
|
}
|
list.add(string);
|
}
|
|
return list;
|
}
|
|
/**
|
* 下划线转驼峰命名
|
*/
|
public static String toUnderScoreCase(String str)
|
{
|
if (str == null)
|
{
|
return null;
|
}
|
StringBuilder sb = new StringBuilder();
|
// 前置字符是否大写
|
boolean preCharIsUpperCase = true;
|
// 当前字符是否大写
|
boolean curreCharIsUpperCase = true;
|
// 下一字符是否大写
|
boolean nexteCharIsUpperCase = true;
|
for (int i = 0; i < str.length(); i++)
|
{
|
char c = str.charAt(i);
|
if (i > 0)
|
{
|
preCharIsUpperCase = Character.isUpperCase(str.charAt(i - 1));
|
}
|
else
|
{
|
preCharIsUpperCase = false;
|
}
|
|
curreCharIsUpperCase = Character.isUpperCase(c);
|
|
if (i < (str.length() - 1))
|
{
|
nexteCharIsUpperCase = Character.isUpperCase(str.charAt(i + 1));
|
}
|
|
if (preCharIsUpperCase && curreCharIsUpperCase && !nexteCharIsUpperCase)
|
{
|
sb.append(SEPARATOR);
|
}
|
else if ((i != 0 && !preCharIsUpperCase) && curreCharIsUpperCase)
|
{
|
sb.append(SEPARATOR);
|
}
|
sb.append(Character.toLowerCase(c));
|
}
|
|
return sb.toString();
|
}
|
|
/**
|
* 是否包含字符串
|
*
|
* @param str 验证字符串
|
* @param strs 字符串组
|
* @return 包含返回true
|
*/
|
public static boolean inStringIgnoreCase(String str, String... strs)
|
{
|
if (str != null && strs != null)
|
{
|
for (String s : strs)
|
{
|
if (str.equalsIgnoreCase(trim(s)))
|
{
|
return true;
|
}
|
}
|
}
|
return false;
|
}
|
|
/**
|
* 将下划线大写方式命名的字符串转换为驼峰式。如果转换前的下划线大写方式命名的字符串为空,则返回空字符串。 例如:HELLO_WORLD->HelloWorld
|
*
|
* @param name 转换前的下划线大写方式命名的字符串
|
* @return 转换后的驼峰式命名的字符串
|
*/
|
public static String convertToCamelCase(String name)
|
{
|
StringBuilder result = new StringBuilder();
|
// 快速检查
|
if (name == null || name.isEmpty())
|
{
|
// 没必要转换
|
return "";
|
}
|
else if (!name.contains("_"))
|
{
|
// 不含下划线,仅将首字母大写
|
return name.substring(0, 1).toUpperCase() + name.substring(1);
|
}
|
// 用下划线将原始字符串分割
|
String[] camels = name.split("_");
|
for (String camel : camels)
|
{
|
// 跳过原始字符串中开头、结尾的下换线或双重下划线
|
if (camel.isEmpty())
|
{
|
continue;
|
}
|
// 首字母大写
|
result.append(camel.substring(0, 1).toUpperCase());
|
result.append(camel.substring(1).toLowerCase());
|
}
|
return result.toString();
|
}
|
|
/**
|
* 驼峰式命名法 例如:user_name->userName
|
*/
|
public static String toCamelCase(String s)
|
{
|
if (s == null)
|
{
|
return null;
|
}
|
s = s.toLowerCase();
|
StringBuilder sb = new StringBuilder(s.length());
|
boolean upperCase = false;
|
for (int i = 0; i < s.length(); i++)
|
{
|
char c = s.charAt(i);
|
|
if (c == SEPARATOR)
|
{
|
upperCase = true;
|
}
|
else if (upperCase)
|
{
|
sb.append(Character.toUpperCase(c));
|
upperCase = false;
|
}
|
else
|
{
|
sb.append(c);
|
}
|
}
|
return sb.toString();
|
}
|
|
@SuppressWarnings("unchecked")
|
public static <T> T cast(Object obj)
|
{
|
return (T) obj;
|
}
|
}
|