0%

判断字符串中是否包含简体、繁体中文,或者简体和繁体之间的转换,可以使用如下API。

maven项目,添加如下依赖。

1
2
3
4
5
<dependency>
<groupId>com.github.houbb</groupId>
<artifactId>opencc4j</artifactId>
<version>1.7.2</version>
</dependency>
1
2
3
ZhConverterUtil.isTraditional("中華");

ZhConverterUtil.toSimple("中華");

有个需求是合并两个map,并对相同key的元素的value进行求和。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
public static void main(String[] args) {

List<String> list = new ArrayList<>();
list.add("A");
list.add("B");
list.add("C");
list.add("B");
list.add("B");
list.add("C");
list.add("A");
list.add("D");

Map<String, Long> map = list.stream().collect(Collectors.groupingBy(k -> k, Collectors.counting()));
System.out.println("map: " + map);

List<String> list2 = new ArrayList<>();
list2.add("B");
list2.add("B");
list2.add("B");
list2.add("B");
list2.add("B");
list2.add("C");
list2.add("A");

Map<String, Long> map2 = list2.stream().collect(Collectors.groupingBy(k -> k, Collectors.counting()));

System.out.println("map2: " + map2);

map2.forEach((k, v) -> map.merge(k, v, (v1, v2) -> v1 + v2));

System.out.println("map: " + map);
}

上面这种方法会修改map的值,还有一种方法不会修改map的值,会新生成一个map。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
public class MapMergeDemo {

public static void main(String[] args) {

HashMap<String, Integer> m = new HashMap<>();
HashMap<String, Integer> m2 = new HashMap<>();

m.put("apple", 2);
m.put("pear", 3);
m2.put("apple", 9);
m2.put("banana", 6);

// method1
Map<String, Long> mapResult = Stream.of(m, m2)
.flatMap(map -> map.entrySet().stream())
.collect(Collectors.groupingBy(Map.Entry::getKey,
Collectors.summingLong(Map.Entry::getValue)));

System.out.println(mapResult);

}
}

假如说有以下List,List的元素存放的数据为:苹果:2, 香蕉:3 类似这样的数据。要统计每类水果的数量。

1
2
3
4
5
6
7
8
9
10
11
Map<String, Integer> fruitCountMap = fruitStrList.stream()
// 过滤掉空字符串
.filter(StringUtils::isNotEmpty)
// 按逗号拆分,并压平
.flatMap(row -> Arrays.stream(row.split(",")))
// 生成map,相同的Key,累加value
.collect(Collectors.toMap(
entry -> entry.split(":")[0],
entry -> Integer.parseInt(entry.split(":")[1]),
Integer::sum)
);

cron表达式,一般情况下,六位。

cron = “

[秒] [分] [时] [日] [月] [星期几] {年份}

每个字段允许的值是不一样的

秒Second 0-59 , - * /
0-59 , - * /
小时 0-23 , - * /
日期 1-31 , - * ? / L W C
月份 1-12 或者 JAN-DEC , - * /
星期 1-7 或者 SUN-SAT , - * ? / L C #
年(可选)留空, 1970-2099 , - * /

Seconds (秒) :可以用数字0-59 表示,
Minutes(分) :可以用数字0-59 表示,
Hours(时) :可以用数字0-23表示,
Day-of-Month(天) :可以用数字1-31 中的任一一个值,但要注意一些特别的月份
Month(月) :可以用0-11 或用字符串 “JAN, FEB, MAR, APR, MAY, JUN, JUL, AUG, SEP, OCT, NOV and DEC” 表示
Day-of-Week(每周):可以用数字1-7表示(1 = 星期日)或用字符口串“SUN, MON, TUE, WED, THU, FRI and SAT”表示

每个符号的意义:

  • 表示所有值;
    ? 表示未说明的值,即不关心它为何值;
  • 表示一个指定的范围;
    , 表示附加一个可能值;
    / 符号前表示开始时间,符号后表示每次递增的值;
    L(“last”) (“last”) “L” 用在day-of-month字段意思是 “这个月最后一天”;用在 day-of-week字段, 它简单意思是 “7” or “SAT”。 如果在day-of-week字段里和数字联合使用,它的意思就是 “这个月的最后一个星期几” – 例如: “6L” means “这个月的最后一个星期五”. 当我们用“L”时,不指明一个列表值或者范围是很重要的,不然的话,我们会得到一些意想不到的结果。
    W(“weekday”) 只能用在day-of-month字段。用来描叙最接近指定天的工作日(周一到周五)。例如:在day-of-month字段用“15W”指“最接近这个 月第15天的工作日”,即如果这个月第15天是周六,那么触发器将会在这个月第14天即周五触发;如果这个月第15天是周日,那么触发器将会在这个月第 16天即周一触发;如果这个月第15天是周二,那么就在触发器这天触发。注意一点:这个用法只会在当前月计算值,不会越过当前月。“W”字符仅能在 day-of-month指明一天,不能是一个范围或列表。也可以用“LW”来指定这个月的最后一个工作日。

    只能用在day-of-week字段。用来指定这个月的第几个周几。例:在day-of-week字段用”6#3”指这个月第3个周五(6指周五,3指第3个)。如果指定的日期不存在,触发器就不会触发。

    C 指和calendar联系后计算过的值。例:在day-of-month 字段用“5C”指在这个月第5天或之后包括calendar的第一天;在day-of-week字段用“1C”指在这周日或之后包括calendar的第一天。

一些cron表达式案例
/5 ? 每隔5秒执行一次
0
/1 ? 每隔1分钟执行一次
0 0 5-15
? 每天5-15点整点触发
0 0/3
? 每三分钟触发一次
0 0-5 14 ? 在每天下午2点到下午2:05期间的每1分钟触发
0 0/5 14 ? 在每天下午2点到下午2:55期间的每5分钟触发
0 0/5 14,18 ? 在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发
0 0/30 9-17 ? 朝九晚五工作时间内每半小时
0 0 10,14,16 ? 每天上午10点,下午2点,4点

0 0 12 ? WED 表示每个星期三中午12点
0 0 17 ?
TUES,THUR,SAT 每周二、四、六下午五点
0 10,44 14 ? 3 WED 每年三月的星期三的下午2:10和2:44触发
0 15 10 ? MON-FRI 周一至周五的上午10:15触发
0 0 23 L
? 每月最后一天23点执行一次
0 15 10 L ? 每月最后一日的上午10:15触发
0 15 10 ?
6L 每月的最后一个星期五上午10:15触发
0 15 10 ? 2005 2005年的每天上午10:15触发
0 15 10 ? 6L 2002-2005 2002年至2005年的每月的最后一个星期五上午10:15触发
0 15 10 ?
6#3 每月的第三个星期五上午10:15触发

“30 ?” 每半分钟触发任务
“30 10 ?” 每小时的10分30秒触发任务
“30 10 1
?” 每天1点10分30秒触发任务
“30 10 1 20
?” 每月20号1点10分30秒触发任务
“30 10 1 20 10 ? “ 每年10月20号1点10分30秒触发任务
“30 10 1 20 10 ? 2011” 2011年10月20号1点10分30秒触发任务
“30 10 1 ? 10
2011” 2011年10月每天1点10分30秒触发任务
“30 10 1 ? 10 SUN 2011” 2011年10月每周日1点10分30秒触发任务
“15,30,45 ?” 每15秒,30秒,45秒时触发任务
“15-45 ?” 15到45秒内,每秒都触发任务
“15/5 ?” 每分钟的每15秒开始触发,每隔5秒触发一次
“15-30/5 ?” 每分钟的15秒到30秒之间开始触发,每隔5秒触发一次
“0 0/3 ?” 每小时的第0分0秒开始,每三分钟触发一次
“0 15 10 ?
MON-FRI” 星期一到星期五的10点15分0秒触发任务
“0 15 10 L ?” 每个月最后一天的10点15分0秒触发任务
“0 15 10 LW
?” 每个月最后一个工作日的10点15分0秒触发任务
“0 15 10 ? 5L” 每个月最后一个星期四的10点15分0秒触发任务
“0 15 10 ?
5#3” 每个月第三周的星期四的10点15分0秒触发任务