java中输⼊⽇期_Java中的⽇期操作
在⽇志中常⽤的记录当前时间及程序运⾏时长的⽅法:
public void inject(Path urlDir) throws Exception {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
long start = System.currentTimeMillis();
LOG.info("InjectorJob: starting at " + sdf.format(start));
LOG.info("InjectorJob: Injecting urlDir: " + urlDir);
ArgMap(Nutch.ARG_SEEDDIR, urlDir));
long end = System.currentTimeMillis();
LOG.info("Injector: finished at " + sdf.format(end) + ", elapsed: "
+ TimingUtil.elapsedTime(start, end));
}
关键点是:
1、定义⽇期显⽰格式
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");2、获取当前时间
long start = System.currentTimeMillis();3、使⽤某种格式显⽰当前时间
LOG.info("InjectorJob: starting at " + sdf.format(start));
Java⽇期时间使⽤总结
⼀、Java中的⽇期概述
⽇期在Java中是⼀块⾮常复杂的内容,对于⼀个⽇期在不同的语⾔国别环境中,⽇期的国际化,⽇期和时间之间的转换,⽇期的加减运算,⽇期的展⽰格式都是⾮常复杂的问题。
在Java中,操作⽇期主要涉及到⼀下⼏个类:
1、java.util.Date
类 Date 表⽰特定的瞬间,精确到毫秒。从 JDK 1.1 开始,应该使⽤ Calendar 类实现⽇期和时间字段之间转换,使⽤ DateFormat 类来格式化和分析⽇期字符串。Date 中的把⽇期解释为年、⽉、⽇、⼩时、分钟和秒值的⽅法已废弃。
2、DateFormat(抽象类)
DateFormat 是⽇期/时间格式化⼦类的抽象类,它以与语⾔⽆关的⽅式格式化并分析⽇期或时间。⽇期/时间格式化⼦类(如SimpleDateFormat)允许进⾏格式化(也就是⽇期 -> ⽂本)、分析(⽂本-> ⽇期)和标准化。将⽇期表⽰为 Date 对象,或者表⽰为从
GMT(格林尼治标准时间)1970 年,1 ⽉ 1 ⽇ 00:00:00 这⼀刻开始的毫秒数。
3、SimpleDateFormat(DateFormat的直接⼦类)
SimpleDateFormat 是⼀个以与语⾔环境相关的⽅式来格式化和分析⽇期的具体类。它允许进⾏格式化(⽇期 -> ⽂本)、分析(⽂本 -> ⽇期)和规范化。
SimpleDateFormat 使得可以选择任何⽤户定义的⽇期-时间格式的模式。但是,仍然建议通过 DateFormat 中的 getTimeInstance、getDateInstance 或 getDateTimeInstance 来新的创建⽇期-时间格式化程序。
4、java.util.Calendar(抽象类)
Calendar 类是⼀个抽象类,它为特定瞬间与⼀组诸如 YEAR、MONTH、DAY_OF_MONTH、HOUR 等 ⽇历字段之间的转换提供了⼀些⽅法,并为操作⽇历字段(例如获得下星期的⽇期)提供了⼀些⽅法。瞬间可⽤毫秒值来表⽰,它是距历元(即格林威治标准时间 1970 年 1⽉ 1 ⽇的 00:00:00.000,格⾥⾼利历)的偏移量。
与其他语⾔环境敏感类⼀样,Calendar 提供了⼀个类⽅法 getInstance,以获得此类型的⼀个通⽤的对象。Calendar 的 getInstance ⽅法返回⼀个 Calendar 对象,其⽇历字段已由当前⽇期和时间初始化。
5、java.util.GregorianCalendar(Calendar的直接⼦类)
GregorianCalendar 是 Calendar 的⼀个具体⼦类,提供了世界上⼤多数国家使⽤的标准⽇历系统。
GregorianCalendar 是⼀种混合⽇历,在单⼀间断性的⽀持下同时⽀持儒略历和格⾥⾼利历系统,在默认情况下,它对应格⾥⾼利⽇历创⽴时的格⾥⾼利历⽇期(某些国家是在 1582 年 10 ⽉ 15 ⽇创⽴,在其他国家要晚⼀些)。可由调⽤⽅通过调⽤ setGregorianChange()来更改起始⽇期。
⼆、java.util.Date的使⽤
1、java.util.Date的API简介
类 java.util.Date 表⽰特定的瞬间,精确到毫秒。提供了很多的⽅法,但是很多已经过时,不推荐使⽤,下⾯仅仅列出没有过时的⽅法:
构造⽅法摘要
-------------
Date()
分配 Date 对象并⽤当前时间初始化此对象,以表⽰分配它的时间(精确到毫秒)。
Date(long date)
分配 Date 对象并初始化此对象,以表⽰⾃从标准基准时间(称为“历元(epoch)”,即 1970 年 1 ⽉ 1 ⽇ 00:00:00 GMT)以来的指定毫秒数。
⽅法摘要
-------------
boolean after(Date when)
测试此⽇期是否在指定⽇期之后。
boolean before(Date when)
测试此⽇期是否在指定⽇期之前。
Object clone()
返回此对象的副本。
int compareTo(Date anotherDate)
⽐较两个⽇期的顺序。
boolean equals(Object obj)
⽐较两个⽇期的相等性。
long getTime()
返回⾃ 1970 年 1 ⽉ 1 ⽇ 00:00:00 GMT 以来此 Date 对象表⽰的毫秒数。
int hashCode()
返回此对象的哈希码值。
void setTime(long time)
设置此 Date 对象,以表⽰ 1970 年 1 ⽉ 1 ⽇ 00:00:00 GMT 以后 time 毫秒的时间点。
String toString()
把此 Date 对象转换为以下形式的 String: dow mon dd hh:mm:ss zzz yyyy 其中:
dow 是⼀周中的某⼀天 (Sun, Mon, Tue, Wed, Thu, Fri, Sat)。
mon 是⽉份 (Jan, Feb, Mar, Apr, May, Jun, Jul, Aug, Sep, Oct, Nov, Dec)。
dd 是⼀⽉中的某⼀天(01 ⾄ 31),显⽰为两位⼗进制数。
hh 是⼀天中的⼩时(00 ⾄ 23),显⽰为两位⼗进制数。
mm 是⼩时中的分钟(00 ⾄ 59),显⽰为两位⼗进制数。
ss 是分钟中的秒数(00 ⾄ 61),显⽰为两位⼗进制数。
zzz 是时区(并可以反映夏令时)。标准时区缩写包括⽅法 parse 识别的时区缩写。如果不提供时区信息,则 zzz 为空,即根本不包括任何字符。
yyyy 是年份,显⽰为 4 位⼗进制数。
下⾯是⼀个Date类的综合实例:
import java.util.Date;
/**
* Created by IntelliJ IDEA.
* User: leizhimin
* Date: 2007-11-30
* Time: 8:45:44
* ⽇期测试
*/
public class TestDate {
public static
void main(String args[]) {
TestDate nowDate = new TestDate();
}
/**
* 获取系统当前时间
* System.currentTimeMillis()返回系统当前时间,结果为1970年1⽉1⽇0时0分0秒开始,到程序执⾏取得系统时间为⽌所经过的毫秒数
* 1秒=1000毫秒
*/
public void getSystemCurrentTime() {
System.out.println("----获取系统当前时间----");
System.out.println("系统当前时间 = " + System.currentTimeMillis());
}
/**
* 通过Date类获取当前⽇期和当前时间
* String()把⽇期转换为dow mon dd hh:mm:ss zzz yyyy
*/
public void getCurrentDate() {
System.out.println("----获取系统当前⽇期----");
//创建并初始化⼀个⽇期(初始值为当前⽇期)
Date date = new Date();
System.out.println("现在的⽇期是 = " + String());
System.out.println("⾃1970年1⽉1⽇0时0分0秒开始⾄今所经历的毫秒数 = " + Time());
}
}
运⾏结果:
----获取系统当前时间----
系统当前时间 = 1196413077278
-
---获取系统当前⽇期----
现在的⽇期是 = Fri Nov 30 16:57:57 CST 2007
⾃1970年1⽉1⽇0时0分0秒开始⾄今所经历的毫秒数 = 1196413077278
Process finished with exit code 0
2、DateFormat抽象类的使⽤
DateFormat 是⽇期/时间格式化⼦类的抽象类,它以与语⾔⽆关的⽅式格式化并分析⽇期或时间。⽇期/时间格式化⼦类(如SimpleDateFormat)允许进⾏格式化(也就是⽇期 -> ⽂本)、分析(⽂本-> ⽇期)和标准化。将⽇期表⽰为 Date 对象,或者表⽰为从
GMT(格林尼治标准时间)1970 年,1 ⽉ 1 ⽇ 00:00:00 这⼀刻开始的毫秒数。
DateFormat 提供了很多类⽅法,以获得基于默认或给定语⾔环境和多种格式化风格的默认⽇期/时间 Formatter。格式化风格包括FULL、LONG、MEDIUM 和 SHORT。⽅法描述中提供了使⽤这些风格的更多细节和⽰例。
DateFormat 可帮助进⾏格式化并分析任何语⾔环境的⽇期。对于⽉、星期,甚⾄⽇历格式(阴历和阳历),其代码可完全与语⾔环境的约定⽆关。
要格式化⼀个当前语⾔环境下的⽇期,可使⽤某个静态⼯⼚⽅法:
myString = DateInstance().format(myDate);
如果格式化多个⽇期,那么获得该格式并多次使⽤它是更为⾼效的做法,这样系统就不必多次获取有关环境语⾔和国家约定的信息了。
DateFormat df = DateInstance();
for (int i = 0; i < myDate.length; ++i) {
output.println(df.format(myDate[i]) + "; ");
}
要格式化不同语⾔环境的⽇期,可在 getDateInstance() 的调⽤中指定它。
DateFormat df = DateInstance(DateFormat.LONG, Locale.FRANCE);
还可使⽤ DateFormat 进⾏分析。
myDate = df.parse(myString);
使⽤ getDateInstance 来获得该国家的标准⽇期格式。另外还提供了⼀些其他静态⼯⼚⽅法。使⽤ getTimeInstance 可获得该国家的时间格式。使⽤ getDateTimeInstance 可获得⽇期和时间格式。可以将不同选项传⼊这些⼯⼚⽅法,以控制结果的长度(从 SHORT 到MEDIUM 到 LONG 再到 FULL)。确切的结果取决于语⾔环境,但是通常:
SHORT 完全为数字,如 12.13.52 或 3:30pm
MEDIUM 较长,如 Jan 12, 1952
string转date的方法
LONG 更长,如 January 12, 1952 或 3:30:32pm
FULL 是完全指定,如 Tuesday, April 12, 1952 AD 或 3:30:42pm PST。
如果愿意,还可以在格式上设置时区。如果想对格式化或分析施加更多的控制(或者给予⽤户更多的控制),可以尝试将从⼯⼚⽅法所获得的DateFormat 强制转换为 SimpleDateFormat。这适⽤于⼤多数国家;只是要记住将其放⼊⼀个 try 代码块中,以防遇到特殊的格式。
还可以使⽤借助 ParsePosition 和 FieldPosition 的分析和格式化⽅法形式来:逐步地分析字符串的各部分。 对齐任意特定的字段,或者出字符串在屏幕上的选择位置。
DateFormat 不是同步的。建议为每个线程创建独⽴的格式实例。如果多个线程同时访问⼀个格式,则它必须保持外部同步。
3、SimpleDateFormat(DateFormat的直接⼦类)的使⽤
SimpleDateFormat 是⼀个以与语⾔环境相关的⽅式来格式化和分析⽇期的具体类。它允许进⾏格式化(⽇期 -> ⽂本)、分析(⽂本 -> ⽇期)和规范化。
SimpleDateFormat 使得可以选择任何⽤户定义的⽇期-时间格式的模式。但是,仍然建议通过 DateFormat 中的 getTimeInstance、getDateInstance 或 getDateTimeInstance 来新的创建⽇期-时间格式化程序。每⼀个这样的类⽅法都能够返回⼀个以默认格式模式初始化的⽇期/时间格式化程序。可以根据需要使⽤ applyPattern ⽅法来修改格式模式。有关使⽤这些⽅法的更多信息,请参阅DateFormat。
⽇期和时间模式
⽇期和时间格式由⽇期和时间模式 字符串指定。在⽇期和时间模式字符串中,未加引号的字母 'A' 到 '
Z' 和 'a' 到 'z' 被解释为模式字母,⽤来表⽰⽇期或时间字符串元素。⽂本可以使⽤单引号 (') 引起来,以免进⾏解释。"''" 表⽰单引号。所有其他字符均不解释;只是在格式化时将它们简单复制到输出字符串,或者在分析时与输⼊字符串进⾏匹配。
定义了以下模式字母(所有其他字符 'A' 到 'Z' 和 'a' 到 'z' 都被保留):
字母
⽇期或时间元素
表⽰
⽰例
G
Era 标志符
AD

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。