java時間正則
1. java用正則表達式判斷字元串是不是時間
具體代碼如下:
1 public static boolean isValidDate(String str) {
2 boolean convertSuccess=true;
3 // 指定日期格式為四位年/兩位月份/兩位日期,注意yyyy/MM/dd區分大小寫;
4 SimpleDateFormat format = new SimpleDateFormat("yyyy/MM/dd HH:mm");
5 try {
6 // 設置lenient為false. 否則SimpleDateFormat會比較寬松地驗證日期,比如2007/02/29會被接受,並轉換成2007/03/01
7 format.setLenient(false);
8 format.parse(str);
9 } catch (ParseException e) {
10 // e.printStackTrace();
11 // 如果throw java.text.ParseException或者NullPointerException,就說明格式不對
12 convertSuccess=false;
13 }
14 return convertSuccess;
2. JAVA 正則表達式提取時間
提取以後還要處理一下
看一下下邊的例子。結果
2012-2-14
2015-13-35 (這樣非法的就需要你自己來處理了。)
--------------------------------------------------------------------------------
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class Other {
public static void main(String[] args) {
String str = "本頁面最後修訂於2012年2月14日 (星期二) 2015-13/35日 11:29。2012-135/14<br /></li>";
Pattern p = Pattern
.compile("[0-9]{4}[年|\\-|/][0-9]{1,2}[月|\\-|/][0-9]{1,2}");
Matcher m = p.matcher(str);
while (m.find()) {
if (!"".equals(m.group())) {
String date = m.group();
date = date.replaceAll("年", "-");
date = date.replaceAll("月", "-");
date = date.replaceAll("/", "-");
System.out.println(date);
}
}
}
}
3. java中基礎問題,正則表達式判斷時間格式:yyyy-M-d String regex="\\d{
[]內是unicode或ascii碼之類的值的范圍,不能簡單的用這種方式。
應該是\\d{4}-([1-9]|1[0-2])-([1-9]|[1-2][0-9]|3[0-1])
4. 用JAVA正則表達式怎麼匹配年月日(比如要求輸入為出生日期)
建議使用 ^(\d{2}|\d{4})[-/](0?[1-9]|1[12])[-/](0?[1-9]|[12]\d|3[01])$ 來匹配(日期不一定有效),然後嘗試轉換成日期.如果要嚴謹點可以用^(\d{2}|\d{4})[-/](((0?[13578]|10|12)[-/](0?[1-9]|[12]\d|3[01]))|((0?[469]|11)[-/](0?[1-9]|[12]\d|30))|(0?2[-/](0?[1-9]|[12]\d)))$但是這里還是有個問題:將所有年份的2月29日都當作有效日期
5. java中日期的正則表達式
\d{4}-\d{2}-d{2}
不知道你這是什麼語言寫的啊,我提供這個正則表達式是沒有問題的。
6. java中Js驗證日期的正則表達式格式為:yyyy/MM/dd
var result=data.match(/((^((1[8-9]\d{2})|([2-9]\d{3}))(\/)(10|12|0?[13578])(\/)(3[01]|[12][0-9]|0?[1-9])$)|(^((1[8-9]\d{2})|([2-9]\d{3}))(\/)(11|0?[469])(\/)(30|[12][0-9]|0?[1-9])$)|(^((1[8-9]\d{2})|([2-9]\d{3}))(\/)(0?2)(\/)(2[0-8]|1[0-9]|0?[1-9])$)|(^([2468][048]00)(\/)(0?2)(\/)(29)$)|(^([3579][26]00)(\/)(0?2)(\/)(29)$)|(^([1][89][0][48])(\/)(0?2)(\/)(29)$)|(^([2-9][0-9][0][48])(\/)(0?2)(\/)(29)$)|(^([1][89][2468][048])(\/)(0?2)(\/)(29)$)|(^([2-9][0-9][2468][048])(\/)(0?2)(\/)(29)$)|(^([1][89][13579][26])(\/)(0?2)(\/)(29)$)|(^([2-9][0-9][13579][26])(\/)(0?2)(\/)(29)$))/);
將所有的(-)改成(\/)不就得了
我很久以前好像寫過一個和這差不多的正則
7. java 正則表達式 匹配[00:00.00]或者[00:00]這兩種歌詞時間格式的正則表達式
下面的代碼就是你想要的:
public static void main(String[] args) {
String regx1="\\[\\d{2}:\\d{2}.\\d{2}\\]";
String regx2="\\[\\d{2}:\\d{2}\\]";
Pattern p = Pattern.compile(regx1);
String str = "[124:00.00]";
Matcher m = p.matcher(str);
if(!m.matches()){
p = Pattern.compile(regx2);
m = p.matcher(str);
if(!m.matches()){
System.out.println("輸入格式不符合要求!");
}else{
System.out.println("輸入格式正確!匹配格式為:"+"[00:00]");
}
}else{
System.out.println("輸入格式正確!匹配格式為:"+"[00:00.00]");
}
}
8. java 匹配時間的正則怎樣寫
4位時間如 00:00
([0-1]\d|2[0-3]):[0-5]\d
單一字元串 加^和$
如果是這樣的時間也匹配 0:30, 8:9用下面這個
\b([0-1]?\d|2[0-3]):([0-5]?\d)\b
單一字元串用這個
^([0-1]?\d|2[0-3]):([0-5]?\d)$
9. java正則表達式的問題,有一個時間字元串(yyyyMMdd),怎麼判斷他在一個時間區間類,時間區間隨時變化。
你這個很簡單,不需要轉成long再比較,java.util.Date已經有after()、before()等方法來比較兩個時間的先後順序了。示例代碼如下:
/**
*檢測一個時間是否在一個時間區間之內
*@paramstart有效的開始時間
*@paramend有效的結束時間
*@paramcheck待檢測時間
*@return
*/
publicbooleancheckValidDay(Datestart,Dateend,Datecheck){
if(check.after(start)&&check.before(end)){
returntrue;
}else{
returnfalse;
}
}
@Test
publicvoidtest()throwsParseException{
StringvalidStartDayStr="20170501";//有效的開始時間
StringvalidEndDayStr="20171231";//有效的結束時間
StringtestDay1Str="20160101";//測試時間1
StringtestDay2Str="20170720";//測試時間2
StringtestDay3Str="20181230";//測試時間3
DateFormatformat=newSimpleDateFormat("yyyyMMdd");
DatestartDay=format.parse(validStartDayStr);
DateendDay=format.parse(validEndDayStr);
DatetestDay1=format.parse(testDay1Str);
DatetestDay2=format.parse(testDay2Str);
DatetestDay3=format.parse(testDay3Str);
System.out.println(checkValidDay(startDay,endDay,testDay1));
System.out.println(checkValidDay(startDay,endDay,testDay2));
System.out.println(checkValidDay(startDay,endDay,testDay3));
}
測試代碼輸出如下:
false
true
false
10. Java裡面效驗日期的正則表達式
publicstaticvoidmain(String[]args)
{
StringcheckValue="20000431112230";
Stringyear=checkValue.substring(0,4);//獲取年份
Stringmonth=checkValue.substring(4,6);//獲取月份
BooleanisLeap=leapYear(Integer.parseInt(year));//判斷閏年
System.out.println(isLeap);
StringBuffereL=newStringBuffer();
StringlongMonth="01030507081012";//31天的月份
Stringfix="([2][0-3]|[0-1][0-9]|[1-9])[0-5][0-9]([0-5][0-9]|[6][0])";
if(isLeap&&month.equals("02")){//針對2月份的情況【閏年】
eL.append("\d{4}([1][0-2]|[0][0-9])([2][0-1]|[1-2][0-9]|[0][1-9]|[1-9])"+fix);
}elseif(!isLeap&&month.equals("02")){//針對2月份的情況【非閏年】
eL.append("\d{4}([1][0-2]|[0][0-9])([2][0-1]|[1-2][0-8]|[0][1-9]|[1-9])"+fix);
}elseif(longMonth.contains(month)){//31天月份
eL.append("\d{4}([1][0-2]|[0][0-9])([3][0-1]|[1-2][0-9]|[0][1-9]|[1-9])"+fix);
}else{//30天月份
eL.append("\d{4}([1][0-2]|[0][0-9])([3][0]|[1-2][0-9]|[0][1-9]|[1-9])"+fix);
}
Patternp=Pattern.compile(eL.toString());
Matcherm=p.matcher(checkValue);
booleanflag=m.matches();
if(flag)
{
System.out.println("格式正確");
}
else
{
System.out.println("格式錯誤");
}
}
publicstaticbooleanleapYear(intyear){
BooleanisLeap=false;
if(((year%100==0)&&(year%400==0))
||((year%100!=0)&&(year%4==0)))
isLeap=true;
returnisLeap;
}