java正则实现各种日期格式化
来源:互联网 发布:a5创业网源码 编辑:程序博客网 时间:2024/05/15 09:07
package
com.st.test;
import
java.text.DateFormat;
import
java.text.SimpleDateFormat;
import
java.util.Date;
import
java.util.HashMap;
import
java.util.regex.Pattern;
public
class
DateFormatUtil {
@SuppressWarnings
(
"finally"
)
public
static
String FormatDate(String dateStr){
HashMap<String, String> dateRegFormat =
new
HashMap<String, String>();
dateRegFormat.put(
"^\\d{4}\\D+\\d{1,2}\\D+\\d{1,2}\\D+\\d{1,2}\\D+\\d{1,2}\\D+\\d{1,2}\\D*$"
,
"yyyy-MM-dd-HH-mm-ss"
);
//2014年3月12日 13时5分34秒,2014-03-12 12:05:34,2014/3/12 12:5:34
dateRegFormat.put(
"^\\d{4}\\D+\\d{2}\\D+\\d{2}\\D+\\d{2}\\D+\\d{2}$"
,
"yyyy-MM-dd-HH-mm"
);
//2014-03-12 12:05
dateRegFormat.put(
"^\\d{4}\\D+\\d{2}\\D+\\d{2}\\D+\\d{2}$"
,
"yyyy-MM-dd-HH"
);
//2014-03-12 12
dateRegFormat.put(
"^\\d{4}\\D+\\d{2}\\D+\\d{2}$"
,
"yyyy-MM-dd"
);
//2014-03-12
dateRegFormat.put(
"^\\d{4}\\D+\\d{2}$"
,
"yyyy-MM"
);
//2014-03
dateRegFormat.put(
"^\\d{4}$"
,
"yyyy"
);
//2014
dateRegFormat.put(
"^\\d{14}$"
,
"yyyyMMddHHmmss"
);
//20140312120534
dateRegFormat.put(
"^\\d{12}$"
,
"yyyyMMddHHmm"
);
//201403121205
dateRegFormat.put(
"^\\d{10}$"
,
"yyyyMMddHH"
);
//2014031212
dateRegFormat.put(
"^\\d{8}$"
,
"yyyyMMdd"
);
//20140312
dateRegFormat.put(
"^\\d{6}$"
,
"yyyyMM"
);
//201403
dateRegFormat.put(
"^\\d{2}\\s*:\\s*\\d{2}\\s*:\\s*\\d{2}$"
,
"yyyy-MM-dd-HH-mm-ss"
);
//13:05:34 拼接当前日期
dateRegFormat.put(
"^\\d{2}\\s*:\\s*\\d{2}$"
,
"yyyy-MM-dd-HH-mm"
);
//13:05 拼接当前日期
dateRegFormat.put(
"^\\d{2}\\D+\\d{1,2}\\D+\\d{1,2}$"
,
"yy-MM-dd"
);
//14.10.18(年.月.日)
dateRegFormat.put(
"^\\d{1,2}\\D+\\d{1,2}$"
,
"yyyy-dd-MM"
);
//30.12(日.月) 拼接当前年份
dateRegFormat.put(
"^\\d{1,2}\\D+\\d{1,2}\\D+\\d{4}$"
,
"dd-MM-yyyy"
);
//12.21.2013(日.月.年)
String curDate =
new
SimpleDateFormat(
"yyyy-MM-dd"
).format(
new
Date());
DateFormat formatter1 =
new
SimpleDateFormat(
"yyyy-MM-dd HH:mm:ss"
);
DateFormat formatter2;
String dateReplace;
String strSuccess=
""
;
try
{
for
(String key : dateRegFormat.keySet()) {
if
(Pattern.compile(key).matcher(dateStr).matches()) {
formatter2 =
new
SimpleDateFormat(dateRegFormat.get(key));
if
(key.equals(
"^\\d{2}\\s*:\\s*\\d{2}\\s*:\\s*\\d{2}$"
)
|| key.equals(
"^\\d{2}\\s*:\\s*\\d{2}$"
)) {
//13:05:34 或 13:05 拼接当前日期
dateStr = curDate +
"-"
+ dateStr;
}
else
if
(key.equals(
"^\\d{1,2}\\D+\\d{1,2}$"
)) {
//21.1 (日.月) 拼接当前年份
dateStr = curDate.substring(
0
,
4
) +
"-"
+ dateStr;
}
dateReplace = dateStr.replaceAll(
"\\D+"
,
"-"
);
// System.out.println(dateRegExpArr[i]);
strSuccess = formatter1.format(formatter2.parse(dateReplace));
break
;
}
}
}
catch
(Exception e) {
System.err.println(
"-----------------日期格式无效:"
+dateStr);
throw
new
Exception(
"日期格式无效"
);
}
finally
{
return
strSuccess;
}
}
public
static
void
main(String[] args) {
String[] dateStrArray=
new
String[]{
"2014-03-12 12:05:34"
,
"2014-03-12 12:05"
,
"2014-03-12 12"
,
"2014-03-12"
,
"2014-03"
,
"2014"
,
"20140312120534"
,
"2014/03/12 12:05:34"
,
"2014/3/12 12:5:34"
,
"2014年3月12日 13时5分34秒"
,
"201403121205"
,
"1234567890"
,
"20140312"
,
"201403"
,
"2000 13 33 13 13 13"
,
"30.12.2013"
,
"12.21.2013"
,
"21.1"
,
"13:05:34"
,
"12:05"
,
"14.1.8"
,
"14.10.18"
};
for
(
int
i=
0
;i<dateStrArray.length;i++){
System.out.println(dateStrArray[i] +
"------------------------------"
.substring(
1
,
30
-dateStrArray[i].length())+ FormatDate(dateStrArray[i]));
}
}
}
0 0
- java正则实现各种日期格式化
- java正则实现各种日期格式化
- java 各种日期格式化工具
- 各种格式化-日期格式化
- JavaScript正则表达式实现日期格式化
- 各种日期格式化
- java DecimalFormat SimpleDateFormat 实现日期、数值格式化
- java中calendar方法实现日期格式化
- C#各种时间格式化/C#日期格式化
- js实现日期格式化
- java 日期格式化 字符串<->日期
- java实现正则表达式判断日期
- java各种字符串格式化
- JAVA格式化时间日期
- java日期格式化
- JAVA格式化日期
- Java日期格式化
- Java日期格式化
- [转]Java7中的ForkJoin并发框架初探(中)——JDK中实现简要分析
- maven编译web项目显示“软件包 javax.servlet.http 不存在"
- [转]Java7中的ForkJoin并发框架初探(下)—— ForkJoin的应用
- web安全测试---AppScan扫描工具
- [转]Java中的随机数生成器:Random,ThreadLocalRandom,SecureRandom
- java正则实现各种日期格式化
- [转]RMI方式Ehcache集群的源码分析
- 并发队列ConcurrentLinkedQueue和阻塞队列LinkedBlockingQueue用法
- 探索 ConcurrentHashMap 高并发性的实现机制
- maven 常用命令
- 虚拟机redhat 9.0上网解决方案
- Oracle数据库悲观锁与乐观锁详解
- SELECT INTO 和 INSERT INTO SELECT 两种表复制语句
- 使用spring框架处理编码问题