`

日期和时间的处理(转载)

    博客分类:
  • java
 
阅读更多

日期和时间的处理不仅在面试题中会考到,在实际项目开发中也是我们经常需要处理的问题,似乎没有哪个项目可以避开它们,我们常常在处理用户的出生年月日、注册日期,订单的创建时间等属性时用到,由此可见其重要性。

 

java.util.Date

 

提到日期和时间,我想大家最先想到应该是java.util.Date类吧。Date类可以精确到毫秒数,这个毫秒数是相对于格林威治标准时间“1970-01-01 00:00:00.000 GMT”的差值。那么,什么是格林威治标准时间呢?要回答这个问题,我们需要先来了解一下世界时间标准方面的知识。世界时间标准主要有UTC,即Coordinated Universal Time(中文名译作世界协调时间、世界统一时间或世界标准时间),以及GMT,即Greenwich Mean Time(中文名译作格林威治标准时间或格林威治平均时间)两种。严格来讲,UTCGMT更加精确一些,不过它们的差值不会超过0.9秒,如果超过了,将会为UTC增加闰秒以与GMT,也就是地球自转周期保持一致。所以在日常使用中,我们可以把UTCGMT一样看待。

 

日期和时间的表示是与我们所处的时区相关联的,如果我们不指定时区,那么它们将以系统默认的时区来显示。我们先来看看如何创建日期对象。Date类有很多个构造器方法,大部分已经不被赞成使用了(Deprecated),不过还剩下两个可以使用的:

public Date() {
	this(System.currentTimeMillis());
}

public Date(long date) { }

 

第一个是无参构造器,使用系统当前时间的毫秒数来创建Date对象,它调用了java.lang.System类的currentTimeMillis()来取得系统的当前时间的毫秒值。这是个本地方法,它的定义如下:

public static native long currentTimeMillis();

 

第二个构造器是根据给定的毫秒数来创建一个与之对应的Date对象,这个毫秒数决定了被创建对象的年、月、日、时、分、秒属性的值。

我们来看看日期和时间在默认时区下的显示效果:

import java.util.Date;

public class DateTest {
	public static void main(String[] args) {
		Date d = new Date();
		// 在默认时区下输出日期和时间值
		System.out.println(d);
	}
}

 

运行结果:

Mon Oct 14 10:45:01 CST 2013

 

大家应该注意到了年份前的“CST”标识,它是China Standard Time的缩写,指的是中国标准时间,也就是我们常说的北京时间。它与UTC的时差是UTC+8:00,就是说北京时间比世界标准时间早8个小时,如果世界标准时间是早上1点,北京时间就是早上9点。一般情况下我们不需要关心时区问题。

 

在创建完Date对象之后,我们可以通过调用getTime()方法来获得该对象的毫秒数值,调用setTime(long time)方法来设置它的毫秒数值,从而影响年、月、日、时、分、秒这些属性。

这两个方法的定义如下:

public long getTime() {
	// other code
}
public void setTime(long time) {
	// other code
}

 

既然Date对象可以表示相对于“1970-01-01 00:00:00.000 GMT”的毫秒数,我们自然可以通过这个值来比较两个日期的大小了,不过对于日期来讲,前后的说法应该更为恰当。而Date类已经为我们提供了这样的方法:

public boolean before(Date when) {
	// other code
}
public boolean after(Date when) {
	// other code
}
public int compareTo(Date anotherDate) {
	// other code
}

 

before()是判断当前日期是否在参数日期之前,即当前日期毫秒数小于参数日期毫秒数;

after()是判断当前日期是否在参数日期之后,即当前日期毫秒数大于参数日期毫秒数。而compareTo()是将当前日期与参数日期比较后,返回一个int型值,它的返回值有三种可能:-101。如果返回-1则表示当前日期在参数日期之前;如果返回0则表示两个日期是同一时刻;返回1则表示当前日期在参数日期之后。虽然我们可以用 compareTo()方法来比较两个Date对象,但是它的设计实际是另有用途的,我们在后面的章节将会讲到。

下面我们就用一个示例来检验一下以上方法的用法:

import java.util.Date;

public class DateTest {
	public static void main(String[] args) {
		// 2013-10-14 11:00:00对应的毫秒数
		long t2013 = 1384398000593L;
		// 1900-01-01 11:00:00对应的毫秒数
		long t1900 = -2206299951875L;
		// 指定毫秒数创建Date对象
		Date d2013 = new Date(t2013);
		// 使用系统默认时间创建Date对象
		Date d1900 = new Date();
		// 通过设置毫秒数改变日期和时间
		d1900.setTime(t1900);
		System.out.println("调用方法:d1900.before(d2013)");
		System.out.print("比较结果:\"1900-01-01 11:00:00\"在\"2013-10-14 11:00:00\"");
		// 使用before()方法比较
		if (d1900.before(d2013)) {
			System.out.println("之前");
		} else {
			System.out.println("之后");
		}
		System.out.println();
		System.out.println("调用方法:d2013.after(d1900)");
		System.out.print("比较结果:\"2013-10-14 11:00:00\"在\"1900-01-01 11:00:00\"");
		// 使用after()方法比较
		if (d2013.after(d1900)) {
			System.out.println("之后");
		} else {
			System.out.println("之前");
		}
		System.out.println();
		System.out.println("调用方法:d1900.compareTo(d2013)");
		System.out.print("比较结果:\"1900-01-01 11:00:00\"在\"2013-10-14 11:00:00\"");
		// 使用compareTo()方法比较
		int i = d1900.compareTo(d2013);
		if (i == -1) {
			System.out.println("之前");
		} else if (i == 1) {
			System.out.println("之后");
		} else if (i == 0) {
			System.out.println("是同一时刻");
		}
	}
}

 

运行结果:

调用方法:d1900.before(d2013)

比较结果:"1900-01-01 11:00:00""2013-10-14 11:00:00"之前

 

调用方法:d2013.after(d1900)

比较结果:"2013-10-14 11:00:00""1900-01-01 11:00:00"之后

 

调用方法:d1900.compareTo(d2013)

比较结果:"1900-01-01 11:00:00""2013-10-14 11:00:00"之前

 

那么如果我们想直接获取或者改变年、月、日、时、分、秒等等这些属性的值时怎么办呢?

Date类当然有完成这些操作的方法,不过遗憾的是它们也都已经不被赞成使用了。我们必须换一个能够提供这些操作的类,这个类就是java.util.Calendar

 

公历历法java.util.GregorianCalendar

 

Calendar是一个抽象类,我们无法直接实例化它,它有一个具体子类实体类java.util.GregorianCalendar,这个类实现的就是我们日常所用的公历历法或者叫做阳历。我们可以直接使用new命令创建它的实例,或者使用Calendar类的这个方法来获得它实例:

public static Calendar getInstance(){
	//other code
}

 

采用上面这个方法时,我们创建的Calendar对象的日期和时间值是对象被创建时系统日期和时间值。当使用new命令时,我们有两种选择,一种是使用系统当前的日期和时间值初始化GregorianCalendar对象;另一种是通过给定年、月、日、时、分、秒等属性值来对其进行初始化。请看下面的例子:

import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.GregorianCalendar;

public class DateTest {
	/**
	 * 以一种较为友好的方式格式化日期时间值
	 * 
	 * @param c 日期时间对象
	 * @return 格式化后的日期时间字符串
	 */
	public static String toFriendlyString(Calendar c) {
		if (c != null) {
			DateFormat df = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");
			return df.format(c.getTime());
		}
		return null;
	}
	
	public static void main(String[] args) {
		Calendar c1 = Calendar.getInstance();
		System.out.println("创建方式:Calendar.getInstance()");
		System.out.println("日期时间:" + DateTest.toFriendlyString(c1));
		System.out.println();
		Calendar c2 = new GregorianCalendar();
		System.out.println("创建方式:new GregorianCalendar()");
		System.out.println("日期时间:" + DateTest.toFriendlyString(c2));
		System.out.println();
		// 参数含义依次为:年、月、日
		Calendar c3 = new GregorianCalendar(2013, 10, 14);
		System.out.println("创建方式:new GregorianCalendar(2013, 10, 14)");
		System.out.println("日期时间:" + DateTest.toFriendlyString(c3));
		System.out.println();
		// 参数含义依次为:年、月、日、时、分
		Calendar c4 = new GregorianCalendar(2013, 10, 14, 15, 10);
		System.out.println("创建方式:new GregorianCalendar(2013, 10, 14, 15, 10)");
		System.out.println("日期时间:" + DateTest.toFriendlyString(c4));
		System.out.println();
		// 参数含义依次为:年、月、日、时、分、秒
		Calendar c5 = new GregorianCalendar(2013, 10, 14, 15, 10, 35);
		System.out.println("创建方式:new GregorianCalendar(2013, 10, 14, 15, 10, 35)");
		System.out.println("日期时间:" + DateTest.toFriendlyString(c5));
	}
}

 

运行结果如下:

创建方式:Calendar.getInstance()

日期时间:20131014 14:18:49

 

创建方式:new GregorianCalendar()

日期时间:20131014 14:18:49

 

创建方式:new GregorianCalendar(2013, 10, 14)

日期时间:20131114 00:00:00

 

创建方式:new GregorianCalendar(2013, 10, 14, 15, 10)

日期时间:20131114 15:10:00

 

创建方式:new GregorianCalendar(2013, 10, 14, 15, 10, 35)

日期时间:20131114 15:10:35

 

为了便于阅读,我们增加一个toFriendlyString(Calendar c)方法,它将日期时间值格式化为一种更加友好易懂的形式,我们将在接下来的内容中讲解它的实现原理。分析运行结果后,我们发现有两个地方需要注意:

1. 在创建GregorianCalendar对象时,月份值都设定为10,但打印结果都是11月份。这并不是我们的代码有问题,而是因为JAVA表示的月份是从0开始的,也就是说它用来表示月份的数值总是比实际月份值小1。因此我们要表示10月份,就是应该设置10-1=9这个值。

2. GregorianCalendar的小时数是24小时制的。

为了避免出现因为忘记处理1的差值而设置了错误的月份,也让代码看起来更加直观,推荐大家使用定义在Calendar类的的这些常量来代替直接用数字表示月份:

一月:Calendar.JANUARY = 0

二月:Calendar.FEBRUARY = 1

三月:Calendar.MARCH = 2

四月:Calendar.APRIL = 3

五月:Calendar.MAY = 4

六月:Calendar.JUNE = 5

七月:Calendar.JULY = 6

八月:Calendar.AUGUST = 7

九月:Calendar.SEPTEMBER = 8

十月:Calendar.OCTOBER = 9

十一月:Calendar.NOVEMBER = 10

十二月:Calendar.DECEMBER = 11

如果我们想要从Calendar对象获得各种属性的值,就需要调用它的get(int field)方法,这个方法接收一个int型的参数,并且根据这个给定参数的值来返回相应的属性的值。该方法的定义如下:

public int get(int field){
	//other code
}

 

我们以一个示例来说明get(int field)方法所能接受的一些常用参数的含义及用法:

import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Calendar;

public class DateTest {
	/**
	 * 以一种较为友好的方式格式化日期时间值
	 * 
	 * @param c 日期时间对象
	 * @return 格式化后的日期时间字符串
	 */
	public static String toFriendlyString(Calendar c) {
		if (c != null) {
			DateFormat df = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss.SSS");
			return df.format(c.getTime());
		}
		return null;
	}
	
	public static void main(String[] args) {
		Calendar c = Calendar.getInstance();
		System.out.println("当前时刻:" + DateTest.toFriendlyString(c));
		System.out.println();
		System.out.println("属性名称:Calendar.AM_PM");
		System.out.println("代表含义:上下午标识,上午返回Calendar.AM=0,下午返回Calendar.PM=1");
		System.out.println("测试结果:" + c.get(Calendar.AM_PM));
		System.out.println();
		System.out.println("属性名称:Calendar.DATE");
		System.out.println("代表含义:一个月中的第几天,同Calendar.DAY_OF_MONTH");
		System.out.println("测试结果:" + c.get(Calendar.DATE));
		System.out.println();
		System.out.println("属性名称:Calendar.DAY_OF_MONTH");
		System.out.println("代表含义:一个月中的第几天,同Calendar.DATE");
		System.out.println("测试结果:" + c.get(Calendar.DAY_OF_MONTH));
		System.out.println();
		System.out.println("属性名称:Calendar.DAY_OF_WEEK");
		System.out.println("代表含义:一周中的第几天,对应星期几,第一天为星期日,于此类推。");
		System.out.println("星期日:Calendar.SUNDAY=1");
		System.out.println("星期一:Calendar.MONDAY=2");
		System.out.println("星期二:Calendar.TUESDAY=3");
		System.out.println("星期三:Calendar.WEDNESDAY=4");
		System.out.println("星期四:Calendar.THURSDAY=5");
		System.out.println("星期五:Calendar.FRIDAY=6");
		System.out.println("星期六:Calendar.SATURDAY=7");
		System.out.println("测试结果:" + c.get(Calendar.DAY_OF_WEEK));
		System.out.println();
		System.out.println("属性名称:Calendar.DAY_OF_WEEK_IN_MONTH");
		System.out.println("代表含义:这一天所对应的星期几在该月中是第几次出现");
		System.out.println("测试结果:" + c.get(Calendar.DAY_OF_WEEK_IN_MONTH));
		System.out.println();
		System.out.println("属性名称:Calendar.DAY_OF_YEAR");
		System.out.println("代表含义:一年中的第几天");
		System.out.println("测试结果:" + c.get(Calendar.DAY_OF_YEAR));
		System.out.println();
		System.out.println("属性名称:Calendar.HOUR");
		System.out.println("代表含义:12小时制下的小时数,中午和午夜表示为0");
		System.out.println("测试结果:" + c.get(Calendar.HOUR));
		System.out.println();
		System.out.println("属性名称:Calendar.HOUR_OF_DAY");
		System.out.println("代表含义:24小时制下的小时数,午夜表示为0");
		System.out.println("测试结果:" + c.get(Calendar.HOUR_OF_DAY));
		System.out.println();
		System.out.println("属性名称:Calendar.MILLISECOND");
		System.out.println("代表含义:毫秒数");
		System.out.println("测试结果:" + c.get(Calendar.MILLISECOND));
		System.out.println();
		System.out.println("属性名称:Calendar.MINUTE");
		System.out.println("代表含义:分钟");
		System.out.println("测试结果:" + c.get(Calendar.MINUTE));
		System.out.println();
		System.out.println("属性名称:Calendar.MONTH");
		System.out.println("代表含义:月份,从0到11表示12个月份,比实际月份值小1");
		System.out.println("测试结果:" + c.get(Calendar.MONTH));
		System.out.println();
		System.out.println("属性名称:Calendar.SECOND");
		System.out.println("代表含义:秒");
		System.out.println("测试结果:" + c.get(Calendar.SECOND));
		System.out.println();
		System.out.println("属性名称:Calendar.WEEK_OF_MONTH");
		System.out.println("代表含义:一个月中的第几个星期");
		System.out.println("测试结果:" + c.get(Calendar.WEEK_OF_MONTH));
		System.out.println();
		System.out.println("属性名称:Calendar.WEEK_OF_YEAR");
		System.out.println("代表含义:一年中的第几个星期");
		System.out.println("测试结果:" + c.get(Calendar.WEEK_OF_YEAR));
		System.out.println();
		System.out.println("属性名称:Calendar.YEAR");
		System.out.println("代表含义:年份");
		System.out.println("测试结果:" + c.get(Calendar.YEAR));
	}
}

 

运行结果如下:

当前时刻:20131014 14:29:43.687

 

属性名称:Calendar.AM_PM

代表含义:上下午标识,上午返回Calendar.AM=0,下午返回Calendar.PM=1

测试结果:1

 

属性名称:Calendar.DATE

代表含义:一个月中的第几天,同Calendar.DAY_OF_MONTH

测试结果:14

 

属性名称:Calendar.DAY_OF_MONTH

代表含义:一个月中的第几天,同Calendar.DATE

测试结果:14

 

属性名称:Calendar.DAY_OF_WEEK

代表含义:一周中的第几天,对应星期几,第一天为星期日,于此类推。

星期日:Calendar.SUNDAY=1

星期一:Calendar.MONDAY=2

星期二:Calendar.TUESDAY=3

星期三:Calendar.WEDNESDAY=4

星期四:Calendar.THURSDAY=5

星期五:Calendar.FRIDAY=6

星期六:Calendar.SATURDAY=7

测试结果:2

 

属性名称:Calendar.DAY_OF_WEEK_IN_MONTH

代表含义:这一天所对应的星期几在该月中是第几次出现

测试结果:2

 

属性名称:Calendar.DAY_OF_YEAR

代表含义:一年中的第几天

测试结果:287

 

属性名称:Calendar.HOUR

代表含义:12小时制下的小时数,中午和午夜表示为0

测试结果:2

 

属性名称:Calendar.HOUR_OF_DAY

代表含义:24小时制下的小时数,午夜表示为0

测试结果:14

 

属性名称:Calendar.MILLISECOND

代表含义:毫秒数

测试结果:687

 

属性名称:Calendar.MINUTE

代表含义:分钟

测试结果:29

 

属性名称:Calendar.MONTH

代表含义:月份,从011表示12个月份,比实际月份值小1

测试结果:9

 

属性名称:Calendar.SECOND

代表含义:秒

测试结果:43

 

属性名称:Calendar.WEEK_OF_MONTH

代表含义:一个月中的第几个星期

测试结果:3

 

属性名称:Calendar.WEEK_OF_YEAR

代表含义:一年中的第几个星期

测试结果:42

 

属性名称:Calendar.YEAR

代表含义:年份

测试结果:2013

 

其中Calendar.DAY_OF_WEEK_IN_MONTH代表的含义比较难理解一些,它表示“这一天所对应的星期几在该月中是第几次出现”。比如20131014日是星期一,在它之前107日也是星期一,因此它是10月份的第二个星期一。所以这时调用get(Calendar.DAY_OF_WEEK_IN_MONTH)就会返回2。这里存在一个简单易记的规律:对于每月的1-7号,它们一定占全了星期一到星期日,所以不管是它们中的哪一天,也不管这一天是星期几,它总是第一个,因此返回18-14号也同样占全了星期一到星期日,但由于1-7号的关系,对于它们总是返回2;以此类推,15-21号返回322-28号返回429-31号返回5

 

Calendar对象和Date对象可以通过Calendar类的如下两个方法进行相互转换:

public final Date getTime() {
	//other code
}
public final void setTime(Date date) {
	//other code
}

 

 

日期格式化与解析

 

我们回头再来看看在上面的例子中定义的toFriendlyString(Calendar c)方法,它将一个Calendar对象的日期时间值以一种很友好的方式来展现,使人们很容易看懂,也符合我们中国人的习惯。这完全得益于抽象类 DateFormat以及它的子类实体类SimpleDateFormat的帮助。这两个类都位于java.text包中,是专门用于日期格式化和解析的类。而这两项工作的核心就是我们为此设定的Pattern,我们可以称之为“日期格式表达式”。

理论上讲日期格式表达式包含全部26个英文字母的大小写,不过它们中的一些字母只是被预留了,并没有确切的含义。目前有效的字母及它们所代表的含义如下:

G:年代标识,表示是公元前还是公元后

y:年份

M:月份

d:日

h:小时,从112,分上下午

H:小时,从023

m:分钟

s:秒

S:毫秒

E:一周中的第几天,对应星期几,第一天为星期日,于此类推

z:时区

D:一年中的第几天

F:这一天所对应的星期几在该月中是第几次出现

w:一年中的第几个星期

W:一个月中的第几个星期

a:上午/下午标识

k:小时,从124

K:小时,从011,区分上下午

 

在日期格式表达式中出现的所有字母,在进行日期格式化操作后,都将被其所代表的含义对应的属性值所替换,并且对某些字母来说,重复次数的不同,格式化后的结果也会有所不同。请看下面的例子:

import java.text.SimpleDateFormat;
import java.util.Date;

public class DateTest {
	public static void main(String[] args) {
		// 使用系统当前日期时间值创建一个Date对象
		Date now = new Date();
		// 创建一个日期格式表达式
		String pattern = "年代:G;年份:y;月份:M;日:d;时(1~12):h;时(0~23):H;分:m;秒:s;毫秒:S;星期:E;上/下午:a;时区:z";
		// 使用日期格式表达式创建一个SimpleDateFormat对象
		SimpleDateFormat df = new SimpleDateFormat(pattern);
		// 调用SimpleDateFormat类的format(Date date)方法对Date对象进行格式化,并返回格式化后的字符串。
		// 该方法继承自java.text.DateFormat类
		System.out.println("1位:" + df.format(now));
		// 创建一个新的日期格式表达式
		pattern = "年代:GG;年份:yy;月份:MM;日:dd;时(1~12):hh;时(0~23):HH;分:mm;秒:ss;毫秒:SS;星期:EE;上/下午:aa;时区:zz";
		// 调用SimpleDateFormat的applyPattern(String pattern)方法用新创建的日期格式表达式替换其原有的
		df.applyPattern(pattern);
		System.out.println("2位:" + df.format(now));
		pattern = "年代:GGG;年份:yyy;月份:MMM;日:ddd;时(1~12):hhh;时(0~23):HHH;分:mmm;秒:sss;毫秒:SSS;星期:EEE;上/下午:aaa;时区:zzz";
		df.applyPattern(pattern);
		System.out.println("3位:" + df.format(now));
		pattern = "年代:GGGG;年份:yyyy;月份:MMMM;日:dddd;时(1~12):hhhh;时(0~23):HHHH;分:mmmm;秒:ssss;毫秒:SSSS;星期:EEEE;上/下午:aaaa;时区:zzzz";
		df.applyPattern(pattern);
		System.out.println("4位:" + df.format(now));
		pattern = "年代:GGGGG;年份:yyyyy;月份:MMMMM;日:ddddd;时(1~12):hhhhh;时(0~23):HHHHH;分:mmmmm;秒:sssss;毫秒:SSSSS;星期:EEEEE;上/下午:aaaaa;时区:zzzzz";
		df.applyPattern(pattern);
		System.out.println("5位:" + df.format(now));
		pattern = "年代:GGGGGG;年份:yyyyyy;月份:MMMMMM;日:dddddd;时(1~12):hhhhhh;时(0~23):HHHHHH;分:mmmmmm;秒:ssssss;毫秒:SSSSSS;星期:EEEEEE;上/下午:aaaaaa;时区:zzzzzz";
		df.applyPattern(pattern);
		System.out.println("6位:" + df.format(now));
	}
}

 

输出结果如下:

1位:年代:公元;年份:13;月份:10;:14;(1~12):2;(0~23):14;:46;:55;毫秒:859;星期:星期一;/下午:下午;时区:CST

2位:年代:公元;年份:13;月份:10;:14;(1~12):02;(0~23):14;:46;:55;毫秒:859;星期:星期一;/下午:下午;时区:CST

3位:年代:公元;年份:13;月份:十月;:014;(1~12):002;(0~23):014;:046;:055;毫秒:859;星期:星期一;/下午:下午;时区:CST

4位:年代:公元;年份:2013;月份:十月;:0014;(1~12):0002;(0~23):0014;:0046;:0055;毫秒:0859;星期:星期一;/下午:下午;时区:中国标准时间

5位:年代:公元;年份:02013;月份:十月;:00014;(1~12):00002;(0~23):00014;:00046;:00055;毫秒:00859;星期:星期一;/下午:下午;时区:中国标准时间

6位:年代:公元;年份:002013;月份:十月;:000014;(1~12):000002;(0~23):000014;:000046;:000055;毫秒:000859;星期:星期一;/下午:下午;时区:中国标准时间

 

如果我们想输出原始的字母,而不是它们所代表含义的替换值,就需要用单引号将它们包含在内,对于预留字母也是如此,虽然它们没有确切的含义。一对单引号可以一次包含多个字母,而两个连续的单引号将输出一个单引号结果,双引号则需要转义后输出。对于26个字母之外的字符,可以放在一对单引号中,也可以直接书写。请看下面的例子:

import java.text.SimpleDateFormat;
import java.util.Date;

public class Test {
	public static void main(String[] args) {
		Date now = new Date();
		SimpleDateFormat df = new SimpleDateFormat("'YEAR': yyyy 'MONTH:' ''MM'' 'DAY:' \"dd\" ");
		System.out.println(df.format(now));
	}
}

 

运行结果:

YEAR: 2013 MONTH: '10' DAY: "14"

 

上面的一些例子中,我们将日期对象转换成一定格式的字符串输出,以得到符合我们习惯的较为友好的表现形式。我们还可以反过来,使用 DateFormat类的parse(String source)方法将具有一定格式的字符串转换为一个Date对象,前提是我们利用前面讲到日期格式表达式语法为其找到一个合适的Pattern。例如:

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;

public class DateTest {
	public static void main(String[] args) throws ParseException {
		String s = "2013-10-14";
		System.out.println("原始字符串:" + s);
		String pattern = "yyyy-MM-dd";
		System.out.println("对应表达式:" + pattern);
		SimpleDateFormat df = new SimpleDateFormat(pattern);
		Date date = df.parse(s);
		System.out.println("转换后的值:" + date);
		System.out.println();
		s = "13年10月14日 15:10:33";
		System.out.println("原始字符串:" + s);
		pattern = "yy年M月d日 HH:mm:ss";
		System.out.println("对应表达式:" + pattern);
		df.applyPattern(pattern);
		date = df.parse(s);
		System.out.println("转换后的值:" + date);
		System.out.println();
		s = "14/10/2013 15:10:33.050";
		System.out.println("原始字符串:" + s);
		pattern = "d/M/yyyy HH:m:s.SSS";
		System.out.println("对应表达式:" + pattern);
		df.applyPattern(pattern);
		date = df.parse(s);
		System.out.println("转换后的值:" + date);
	}
}

 

运行结果:

原始字符串:2013-10-14

对应表达式:yyyy-MM-dd

转换后的值:Mon Oct 14 00:00:00 CST 2013

 

原始字符串:131014 15:10:33

对应表达式:yyMd HH:mm:ss

转换后的值:Mon Oct 14 15:10:33 CST 2013

 

原始字符串:14/10/2013 15:10:33.050

对应表达式:d/M/yyyy HH:m:s.SSS

转换后的值:Mon Oct 14 15:10:33 CST 2013

 

转载自:http://zangweiren.iteye.com/category/34977

分享到:
评论

相关推荐

    java 时间转换(转载)

    在Java编程语言中,时间转换是一项常见的任务,特别是在处理日期和时间数据时。...在实际开发中,确保正确地处理日期和时间,避免出现时区问题,以及有效地进行日期时间的格式化和解析,是至关重要的。

    JavaScript获取系统时间(转载)

    在探讨如何利用JavaScript获取系统时间之前,我们先来理解一下JavaScript中的Date对象,它是处理日期和时间的关键。Date对象提供了多种方法,可以用来获取当前或指定的日期和时间信息,包括年、月、日、小时、分钟、...

    python 正则表达式获取字符串中所有的日期和时间

    首先,文本处理是提取日期和时间的前置步骤。在一些文本数据中,日期可能包含中文的“年”、“月”、“日”等字符,或者使用“/”作为分隔符。因此,我们需要将这些文本中的日期格式统一化,以便于正则表达式的匹配...

    【RPA之家转载视频教程7】Use Case 0021 - Weekly Monthly Yearly Reports Splitting.rar

    我们关注的是一个名为"【RPA之家转载视频教程7】Use Case 0021 - Weekly Monthly Yearly Reports Splitting.rar"的压缩包文件,它包含了一个视频教程,着重讲解如何利用RPA(Robotic Process Automation)自动化处理...

    joda-time2.10.1

    于是就诞生了Joda-Time这个专门处理日期时间的库。(JDK1.8的API已经重写了日期库,引入的java.time包,其实也是借鉴了Joda-Time) --------------------- 作者:--nodeps 来源:CSDN 原文:...

    java面试资料(转载)

    日期和时间的处理是Java程序中常见的需求。早期的java.util.Date和Calendar类由于设计复杂,现在已经推荐使用java.time包下的类,如LocalDate、LocalTime、LocalDateTime等。面试中可能会涉及日期格式化,时间计算,...

    JQuery应用实例学习(强烈推荐)转载.doc

    此外,jQuery 还提供了许多其他工具,如时间、日期和颜色选取插件,如 jQuery UI Datepicker 和 Farbtastic jQuery Color Picker Plugin,以及投票插件如 jQuery Star Rating Plugin。搜索功能方面,jQuery Suggest ...

    仿ipone滚轮搭配Dialog使用实例转载

    在iOS系统中,滚轮常用于日期选择、时间选择等场景。在Android中,我们可以自定义一个滚轮控件,通过滚动事件监听来实现相应的逻辑。 这个实例中的滚轮控件可能基于开源项目或者由原作者自行编写,其核心在于对触摸...

    农历支持的Js控件

    在IT领域,尤其是在Web开发中,常常需要处理各种日期和时间的展示,其中包括农历的显示。"农历支持的Js控件"就是一个专为解决这个问题而设计的JavaScript组件。这个控件能够帮助开发者在网页上方便地添加农历日期的...

    java编程事项(转载收集整理版)

    12. **Java 8及以后的特性**:从Java 8开始,引入了Lambda表达式、Stream API和日期时间API等新特性,这些都极大地增强了Java的简洁性和功能性。 总的来说,"java编程事项"涵盖了Java编程的各个方面,无论你是初学...

    人力资源管理系统,转载分享下

    1. 员工信息管理:系统能集中存储和管理所有员工的基本信息、职位、入职日期、合同详情等,方便查询和更新,确保数据的准确性和一致性。 2. 招聘与应聘管理:支持发布职位、收集简历、筛选候选人,跟踪面试进程,...

    [转载]CIH 1.5 源代码

    感染后的文件不会被重复感染,并且文件的修改日期和时间不会发生改变。 - 为了实现文件感染,CIH使用了`IFSMgr_InstallFileSystemApiHook`函数来挂钩文件系统的API,从而在文件操作时插入自己的代码。 3. **结构...

    程序设计说明书(转载)

    本文档主要关注数据库设计说明书的各个方面,以确保高效、稳定的数据存储和处理。 首先,数据库设计的重要性不言而喻。在任何应用环境中,良好的数据库设计能确保数据的有效存储,同时优化数据之间的相互关系和组织...

    spark使用案例------

    在这个案例中,我们可以学习到如何组织和管理Spark项目,以及如何随着时间推移跟踪和更新代码。 其次,"863sparkTask_20170418-2"可能指的是一个具体的任务或作业,可能是对863计划(中国的一项高科技研究发展计划...

    happyanimee-history_today-master_history_android源码_源码

    5. **日期时间处理**:在处理历史事件时,开发者可能用到了Java 8的日期时间API或者旧版的java.util.Calendar类来处理日期比较和格式化。 6. **异步编程**:考虑到网络请求不应阻塞主线程,项目可能会使用AsyncTask...

    CITEC控制器用户手册(普通显示屏).pdf

    显示屏上还会显示时间、日期、当前温湿度读数、机组状态和设定点等关键信息。 在报警部分,手册提供了详细的故障寻址流程,包括一级菜单流程图,以及故障查找表,帮助用户迅速定位和解决问题。此外,还包含了开/...

    【1949-2021年】中国县域金融机构网点明细(存量、准入、退出)

    数据整理:数据经手工整理和追踪处理,仅限个人学术使用,禁止其他商业平台 转载 二、整理说明 统计网址:https://xkz.cbirc. gov.cn/jr/ 对机构持有、机构失控、机构退出三类明细数据进行整理 利用高德地图...

    vc考勤例子

    4. **时间与日期处理**:考勤系统涉及到大量的时间比较和计算,如计算迟到、早退、加班等。理解C++中的时间日期库函数,如`<ctime>`,并学会如何与数据库中的时间字段进行交互是必要的。 5. **数据结构与算法**:...

    电脑基本操作技巧(转载)

    - 手动调整时间与日期 **7. 压缩文件与文件夹** - **描述**:介绍了如何使用内置工具压缩与解压文件。 - **知识点**: - 压缩文件的步骤 - 解压 ZIP 文件的方法 - 压缩格式的选择 **8. 减少 CPU 资源占用** - ...

Global site tag (gtag.js) - Google Analytics