1.數據比對工具
package com.micecs.erp.util;
import com.baomidou.mybatisplus.core.enums.IEnum;
import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
import java.math.BigDecimal;
import java.util.*;
public class CompareListUtil {
public static void main(String[] args) {
complexCompare();
System.out.println("=============");
simpleCompare();
}
public static void complexCompare() {
List<ContentValues> sourceDataList = DataGenerateUtil.getSourceDataList();
List<ContentValues> targetDataList = DataGenerateUtil.getTargetDataList();
List<ContentValues> compareSourceDataList;
List<ContentValues> compareTargetDataList;
Integer size = 0;
Map<ContentValues, CompareModelEnum> map = new HashMap<>(size);
if (sourceDataList.size() > targetDataList.size()) {
size = sourceDataList.size();
compareSourceDataList = new ArrayList<>(sourceDataList);
compareTargetDataList = new ArrayList<>(targetDataList);
} else {
size = targetDataList.size();
compareSourceDataList = new ArrayList<>(targetDataList);
compareTargetDataList = new ArrayList<>(targetDataList);
}
compareSourceDataList.stream().forEach(vo -> map.put(vo, CompareModelEnum.DELETE));
for (ContentValues value : compareTargetDataList) {
if (map.containsKey(value)) {
map.put(value, CompareModelEnum.UPDATE);
} else {
map.put(value, CompareModelEnum.INSERT);
}
}
CompareResult insert = new CompareResult(CompareModelEnum.INSERT, Lists.newArrayList());
CompareResult update = new CompareResult(CompareModelEnum.UPDATE, Lists.newArrayList());
CompareResult delete = new CompareResult(CompareModelEnum.DELETE, Lists.newArrayList());
map.forEach((key, value) -> {
switch (value) {
case INSERT:
insert.getValues().add(key);
break;
case UPDATE:
update.getValues().add(key);
break;
default:
delete.getValues().add(key);
}
});
System.out.println("待添加:" + insert.toString());
System.out.println("待刪除:" + delete.toString());
System.out.println("待修改:" + update.toString());
}
public static void simpleCompare() {
List<ContentValues> sourceDataList = DataGenerateUtil.getSourceDataList();
List<ContentValues> targetDataList = DataGenerateUtil.getTargetDataList();
getSimpleCompareResult(sourceDataList, targetDataList);
}
public static Map<CompareModelEnum, List<ContentValues>> getSimpleCompareResult(List<ContentValues> sourceList, List<ContentValues> targetList) {
Map<CompareModelEnum, List<ContentValues>> mapList = Maps.newHashMap();
List<List<ContentValues>> result = Lists.newArrayList();
List<ContentValues> erpIdCopy = Lists.newArrayList(sourceList);
sourceList.retainAll(targetList);
result.add(new ArrayList<>(sourceList));
mapList.put(CompareModelEnum.UPDATE, sourceList);
System.out.println("比對交集:待修改的 :" + sourceList.toString());
targetList.removeAll(sourceList);
result.add(new ArrayList<>(targetList));
mapList.put(CompareModelEnum.INSERT, sourceList);
System.out.println(("比對差集:待添加的 " + targetList.toString()));
erpIdCopy.removeAll(targetList);
sourceList.addAll(targetList);
erpIdCopy.removeAll(sourceList);
result.add(new ArrayList<>(erpIdCopy));
mapList.put(CompareModelEnum.DELETE, sourceList);
System.out.println(("比對後待刪除的 " + erpIdCopy.toString()));
return mapList;
}
}
@Data
class CompareResult {
private CompareModelEnum key;
private List<ContentValues> values;
public CompareResult(CompareModelEnum key, List<ContentValues> values) {
this.key = key;
this.values = values;
}
@Override
public String toString() {
return "CompareResult{" +
"key=" + key +
", values=" + values +
'}';
}
}
enum CompareModelEnum implements IEnum<Integer> {
UPDATE(1, "待更新"),
INSERT(2, "待插入"),
DELETE(3, "待刪除");
private Integer value;
private String desc;
CompareModelEnum(Integer value, String desc) {
this.value = value;
this.desc = desc;
}
@Override
public Integer getValue() {
return value;
}
public static CompareModelEnum valueOf(Integer code) {
for (CompareModelEnum value : CompareModelEnum.values()) {
if (Objects.equals(value.getValue(), code)) {
return value;
}
}
throw new RuntimeException("無匹配的");
}
}
@Data
class ContentValues {
private String rfpNo;
private Integer supplierType;
private Long supplierId;
private BigDecimal price;
private BigDecimal commissionMoney;
@Override
public String toString() {
return "\nContentValues{" +
"rfpNo='" + rfpNo + '\'' +
", supplierId=" + supplierId +
", price=" + price +
", commissionMoney=" + commissionMoney +
", supplierType=" + supplierType +
'}';
}
@Override
public boolean equals(Object obj) {
if (obj == this) {
return true;
}
if (!(obj instanceof ContentValues)) {
return false;
}
ContentValues content = (ContentValues) obj;
return supplierId.equals(content.getSupplierId()) &&
rfpNo.equals(content.getRfpNo()) &&
price.compareTo(content.getPrice()) == 0 &&
commissionMoney.compareTo(content.getCommissionMoney()) == 0;
}
@Override
public int hashCode() {
return Objects.hash(supplierId, rfpNo, price, commissionMoney);
}
}
class DataGenerateUtil {
public static List<ContentValues> getSourceDataList() {
List<ContentValues> list = Lists.newArrayList();
ContentValues value1 = new ContentValues();
value1.setRfpNo("rfp_01");
value1.setSupplierId(100L);
value1.setCommissionMoney(new BigDecimal(100));
value1.setPrice(new BigDecimal(1000));
value1.setSupplierType(1);
ContentValues value2 = new ContentValues();
value2.setRfpNo("rfp_01");
value2.setSupplierId(200L);
value2.setCommissionMoney(new BigDecimal(200));
value2.setPrice(new BigDecimal(2000));
value2.setSupplierType(1);
ContentValues value3 = new ContentValues();
value3.setRfpNo("rfp_02");
value3.setSupplierId(300L);
value3.setCommissionMoney(new BigDecimal(300));
value3.setPrice(new BigDecimal(3000));
value3.setSupplierType(1);
ContentValues value4 = new ContentValues();
value4.setRfpNo("rfp_03");
value4.setSupplierId(400L);
value4.setCommissionMoney(new BigDecimal(400));
value4.setPrice(new BigDecimal(4000));
value4.setSupplierType(2);
ContentValues value5 = new ContentValues();
value5.setRfpNo("rfp_03");
value5.setSupplierId(500L);
value5.setCommissionMoney(new BigDecimal(500));
value5.setPrice(new BigDecimal(5000));
value5.setSupplierType(2);
list.add(value1);
list.add(value2);
list.add(value3);
list.add(value4);
list.add(value5);
return list;
}
public static List<ContentValues> getTargetDataList() {
List<ContentValues> list = Lists.newArrayList();
ContentValues value1 = new ContentValues();
value1.setRfpNo("rfp_01");
value1.setSupplierId(100L);
value1.setCommissionMoney(new BigDecimal(100));
value1.setPrice(new BigDecimal(1000));
value1.setSupplierType(1);
ContentValues value2 = new ContentValues();
value2.setRfpNo("rfp_01");
value2.setSupplierId(200L);
value2.setCommissionMoney(new BigDecimal(2100));
value2.setPrice(new BigDecimal(21000));
value2.setSupplierType(1);
ContentValues value4 = new ContentValues();
value4.setRfpNo("rfp_04");
value4.setSupplierId(700L);
value4.setCommissionMoney(new BigDecimal(700));
value4.setPrice(new BigDecimal(7000));
value4.setSupplierType(2);
ContentValues value5 = new ContentValues();
value5.setRfpNo("rfp_03");
value5.setSupplierId(500L);
value5.setCommissionMoney(new BigDecimal(1000));
value5.setPrice(new BigDecimal(10000));
value5.setSupplierType(2);
list.add(value1);
list.add(value2);
list.add(value4);
list.add(value5);
return list;
}
}
2.漢字轉拼音
package com.micecs.erp.util.thirdpart;
import java.util.Random;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import net.sourceforge.pinyin4j.PinyinHelper;
import net.sourceforge.pinyin4j.format.HanyuPinyinCaseType;
import net.sourceforge.pinyin4j.format.HanyuPinyinOutputFormat;
import net.sourceforge.pinyin4j.format.HanyuPinyinToneType;
import net.sourceforge.pinyin4j.format.exception.BadHanyuPinyinOutputFormatCombination;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class CharacterUtil {
private static final Logger LOGGER = LoggerFactory.getLogger(CharacterUtil.class);
public static String ConvertChinese2Pinyin(String chinese, boolean full) {
String regExp = "^[\u4E00-\u9FFF]+$";
StringBuffer sb = new StringBuffer();
if (chinese == null || "".equals(chinese.trim())) {
return "";
}
String pinyin;
for (int i = 0; i < chinese.length(); i++) {
char unit = chinese.charAt(i);
if (match(String.valueOf(unit), regExp)) {
pinyin = convertSingleChinese2Pinyin(unit);
if (full) {
sb.append(pinyin);
} else {
sb.append(pinyin.charAt(0));
}
} else {
sb.append(unit);
}
}
return sb.toString();
}
private static String convertSingleChinese2Pinyin(char chinese) {
HanyuPinyinOutputFormat outputFormat = new HanyuPinyinOutputFormat();
outputFormat.setToneType(HanyuPinyinToneType.WITHOUT_TONE);
String[] res;
StringBuffer sb = new StringBuffer();
try {
res = PinyinHelper.toHanyuPinyinStringArray(chinese, outputFormat);
sb.append(res[0]);
} catch (Exception e) {
LOGGER.error("CONVERT SINGLE CHINESE TO PINYIN ERROR", e);
return "";
}
return sb.toString();
}
public static boolean match(String str, String regex) {
Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(str);
return matcher.find();
}
public static String GetStringRandom(int length) {
String val = "";
Random random = new Random(1);
int num = 0;
while(num < length){
String charOrNum = random.nextInt(2) % 2 == 0 ? "char" : "num";
if ("char".equalsIgnoreCase(charOrNum)) {
int temp = random.nextInt(2) % 2 == 0 ? 65 : 97;
val += (char) (random.nextInt(26) + temp);
num++;
}
}
return val;
}
public static boolean isChinese(String chinese) {
char[] arr = chinese.toCharArray();
for (char anArr : arr) {
boolean matches = String.valueOf(anArr).matches("[\u4e00-\u9fa5]");
if (matches) {
return true;
}
}
return false;
}
}
3.日期工具類
package com.example.lottery.module.utils;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.time.*;
import java.time.format.DateTimeFormatter;
import java.time.temporal.ChronoUnit;
import java.time.temporal.TemporalUnit;
import java.util.Calendar;
import java.util.Date;
public class DateUtils {
public static final String DATE_TIME_FORMAT = "yyyy-MM-dd HH:mm:ss";
public static final String DATE_FORMAT = "yyyy-MM-dd";
public static final DateTimeFormatter TIME_FORMATTER = DateTimeFormatter.ofPattern("HHmmss");
public static final DateTimeFormatter YEAR_MONTH_FORMATTER = DateTimeFormatter.ofPattern("yyyy-MM");
public static final DateTimeFormatter SHORT_DATE_FORMATTER = DateTimeFormatter.ofPattern("yyMMdd");
public static final DateTimeFormatter DATE_FORMATTER = DateTimeFormatter.ofPattern(DATE_FORMAT);
public static final DateTimeFormatter SHORT_DATETIME_FORMATTER = DateTimeFormatter.ofPattern("yyyyMMddHHmmss");
public static final DateTimeFormatter DATETIME_FORMATTER = DateTimeFormatter.ofPattern(DATE_TIME_FORMAT);
public static final DateTimeFormatter LONG_DATETIME_FORMATTER = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss SSS");
public static String dateConvertToString(Date date, String format) {
LocalDateTime localDateTime = LocalDateTime.ofInstant(date.toInstant(), ZoneId.systemDefault());
DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern(format);
return dateTimeFormatter.format(localDateTime);
}
public static Date stringConvertToDate(String date, String format) throws ParseException {
return new SimpleDateFormat(format).parse(date);
}
public static Date getNow() {
Calendar cal = Calendar.getInstance();
return cal.getTime();
}
public static LocalDateTime getDayStart(LocalDateTime time) {
return time.withHour(0).withMinute(0).withSecond(0).withNano(0);
}
public static LocalDateTime getDayEnd(LocalDateTime time) {
return time.withHour(23).withMinute(59).withSecond(59).withNano(999999999);
}
public static LocalDateTime plus(LocalDateTime time, long number, TemporalUnit field) {
return time.plus(number, field);
}
public static LocalDateTime minu(LocalDateTime time, long number, TemporalUnit field) {
return time.minus(number, field);
}
public static long betweenTwoTime(LocalDateTime startTime, LocalDateTime endTime, ChronoUnit field) {
Period period = Period.between(LocalDate.from(startTime), LocalDate.from(endTime));
if (field == ChronoUnit.YEARS) {
return period.getYears();
}
if (field == ChronoUnit.MONTHS) {
return period.getYears() * 12 + period.getMonths();
}
return field.between(startTime, endTime);
}
public static LocalDate getCurrentLocalDate() {
return LocalDate.now(ZoneOffset.of("+8"));
}
public static LocalTime getCurrentLocalTime() {
return LocalTime.now(ZoneOffset.of("+8"));
}
public static LocalDateTime getCurrentLocalDateTime() {
return LocalDateTime.now(ZoneOffset.of("+8"));
}
public static String getCurrentDateStr() {
return LocalDate.now(ZoneOffset.of("+8")).format(DATE_FORMATTER);
}
public static String getCurrentShortDateStr() {
return LocalDate.now(ZoneOffset.of("+8")).format(SHORT_DATE_FORMATTER);
}
public static String getCurrentMonthStr() {
return LocalDate.now(ZoneOffset.of("+8")).format(YEAR_MONTH_FORMATTER);
}
public static String getCurrentDateTimeStr() {
return LocalDateTime.now(ZoneOffset.of("+8")).format(DATETIME_FORMATTER);
}
public static String getCurrentLongDateTimeStr() {
return LocalDateTime.now(ZoneOffset.of("+8")).format(LONG_DATETIME_FORMATTER);
}
public static String getCurrentShortDateTimeStr() {
return LocalDateTime.now(ZoneOffset.of("+8")).format(SHORT_DATETIME_FORMATTER);
}
public static String getCurrentTimeStr() {
return LocalTime.now(ZoneOffset.of("+8")).format(TIME_FORMATTER);
}
public static String getCurrentDateStr(String pattern) {
return LocalDate.now(ZoneOffset.of("+8")).format(DateTimeFormatter.ofPattern(pattern));
}
public static String getCurrentDateTimeStr(String pattern) {
return LocalDateTime.now(ZoneOffset.of("+8")).format(DateTimeFormatter.ofPattern(pattern));
}
public static String getCurrentTimeStr(String pattern) {
return LocalTime.now(ZoneOffset.of("+8")).format(DateTimeFormatter.ofPattern(pattern));
}
public static LocalDate parseLocalDate(String dateStr, String pattern) {
return LocalDate.parse(dateStr, DateTimeFormatter.ofPattern(pattern));
}
public static LocalDateTime parseLocalDateTime(String dateTimeStr, String pattern) {
return LocalDateTime.parse(dateTimeStr, DateTimeFormatter.ofPattern(pattern));
}
public static LocalTime parseLocalTime(String timeStr, String pattern) {
return LocalTime.parse(timeStr, DateTimeFormatter.ofPattern(pattern));
}
public static String formatLocalDate(LocalDate date, String pattern) {
return date.format(DateTimeFormatter.ofPattern(pattern));
}
public static String formatLocalDateTime(LocalDateTime datetime, String pattern) {
return datetime.format(DateTimeFormatter.ofPattern(pattern));
}
public static String formatLocalTime(LocalTime time, String pattern) {
return time.format(DateTimeFormatter.ofPattern(pattern));
}
public static LocalDate parseLocalDate(String dateStr) {
return LocalDate.parse(dateStr, DATE_FORMATTER);
}
public static LocalDateTime parseLocalDateTime(String dateTimeStr) {
return LocalDateTime.parse(dateTimeStr, DATETIME_FORMATTER);
}
public static LocalDateTime parseLongLocalDateTime(String longDateTimeStr) {
return LocalDateTime.parse(longDateTimeStr, LONG_DATETIME_FORMATTER);
}
public static LocalTime parseLocalTime(String timeStr) {
return LocalTime.parse(timeStr, TIME_FORMATTER);
}
public static String formatLocalDate(LocalDate date) {
return date.format(DATE_FORMATTER);
}
public static String formatLocalDateTime(LocalDateTime datetime) {
return datetime.format(DATETIME_FORMATTER);
}
public static String formatLocalTime(LocalTime time) {
return time.format(TIME_FORMATTER);
}
public static long periodHours(LocalDateTime startDateTime, LocalDateTime endDateTime) {
return Duration.between(startDateTime, endDateTime).get(ChronoUnit.SECONDS);
}
public static long periodDays(LocalDate startDate, LocalDate endDate) {
return startDate.until(endDate, ChronoUnit.DAYS);
}
public static long periodWeeks(LocalDate startDate, LocalDate endDate) {
return startDate.until(endDate, ChronoUnit.WEEKS);
}
public static long periodMonths(LocalDate startDate, LocalDate endDate) {
return startDate.until(endDate, ChronoUnit.MONTHS);
}
public static long periodYears(LocalDate startDate, LocalDate endDate) {
return startDate.until(endDate, ChronoUnit.YEARS);
}
public static boolean isToday(LocalDate date) {
return getCurrentLocalDate().equals(date);
}
public static Long toEpochMilli(LocalDateTime dateTime) {
return dateTime.atZone(ZoneId.systemDefault()).toInstant().toEpochMilli();
}
public static boolean isLeapYear(LocalDate localDate) {
return localDate.isLeapYear();
}
public static LocalDateTime dateConvertToLocalDateTime(Date date) {
return date.toInstant().atOffset(ZoneOffset.of("+8")).toLocalDateTime();
}
public static Date localDateTimeConvertToDate(LocalDateTime localDateTime) {
return Date.from(localDateTime.toInstant(ZoneOffset.of("+8")));
}
public static LocalDateTime millisecToDatetime(long milliseconds) {
Instant instant = Instant.ofEpochMilli(milliseconds);
return LocalDateTime.ofInstant(instant, ZoneOffset.of("+8"));
}
public static long datatimeToTimestamp(LocalDateTime ldt) {
return ldt.toInstant(ZoneOffset.of("+8")).toEpochMilli();
}
public static Date transferLongToDate(Long millSec) {
return new Date(millSec);
}
public static Date getDateBefore(int day) {
Calendar calendar = Calendar.getInstance();
calendar.add(Calendar.DATE, -day);
return calendar.getTime();
}
public static String getDateBeforeByLocalDateTime(int day) {
return dateConvertToLocalDateTime(getDateBefore(day)).format(DATETIME_FORMATTER);
}
public static String getDateBeforeBySimpleDateFormat(int day, String format) {
Calendar calendar = Calendar.getInstance();
SimpleDateFormat sdf = new SimpleDateFormat(format);
calendar.add(Calendar.DATE, -day);
return sdf.format(calendar.getTime());
}
public static String getDateAfterBySimpleDateFormat(int day, String format) {
Calendar calendar = Calendar.getInstance();
SimpleDateFormat sdf = new SimpleDateFormat(format);
calendar.add(Calendar.DATE, day);
return sdf.format(calendar.getTime());
}
public static void main(String[] args) throws ParseException {
System.out.println(dateConvertToString(new Date(), DATE_FORMAT));
System.out.println(stringConvertToDate("2018-06-01 10:12:05", DATE_FORMAT));
System.out.println(getDateBeforeByLocalDateTime(23));
System.out.println(millisecToDatetime(1563867467000L).format(DATETIME_FORMATTER));
System.out.println(datatimeToTimestamp(getCurrentLocalDateTime()));
System.out.println(getCurrentDateTimeStr("yyyy年MM月dd日 HH:mm:ss"));
System.out.println(getCurrentDateTimeStr());
Date date = getNow();
LocalDateTime localDateTime = dateConvertToLocalDateTime(date);
Long localDateTimeSecond = localDateTime.toEpochSecond(ZoneOffset.of("+8"));
Long dateSecond = date.toInstant().atOffset(ZoneOffset.of("+8")).toEpochSecond();
System.out.println("dateSecond:" + dateSecond);
System.out.println("localDateTimeSecond:" + localDateTimeSecond);
System.out.println(formatLocalDateTime(plus(LocalDateTime.now(), 20, ChronoUnit.MINUTES), "yyyy年MM月dd日 HH:mm"));
System.out.println(formatLocalDateTime(plus(LocalDateTime.now(), 2, ChronoUnit.YEARS), "yyyy年MM月dd日 HH:mm"));
LocalDateTime start = LocalDateTime.of(1993, 10, 13, 11, 11);
LocalDateTime end = LocalDateTime.of(1994, 11, 13, 13, 13);
System.out.println("年:" + betweenTwoTime(start, end, ChronoUnit.YEARS));
System.out.println("月:" + betweenTwoTime(start, end, ChronoUnit.MONTHS));
System.out.println("日:" + betweenTwoTime(start, end, ChronoUnit.DAYS));
System.out.println("半日:" + betweenTwoTime(start, end, ChronoUnit.HALF_DAYS));
System.out.println("小時:" + betweenTwoTime(start, end, ChronoUnit.HOURS));
System.out.println("分鐘:" + betweenTwoTime(start, end, ChronoUnit.MINUTES));
System.out.println("秒:" + betweenTwoTime(start, end, ChronoUnit.SECONDS));
System.out.println("毫秒:" + betweenTwoTime(start, end, ChronoUnit.MILLIS));
}
}