String string = "January 2, 2010";
DateFormat format = new SimpleDateFormat("MMMM d, yyyy", Locale.ENGLISH);
Date date = format.parse(string);
System.out.println(date); // Sat Jan 02 00:00:00 GMT 2010
请注意显式 Locale 争论。如果您省略它,那么它将使用默认的语言环境,而不是输入字符串的月份名称中使用的英语。如果区域设置与输入字符串不匹配,那么您将得到一个 java.text.ParseException 即使格式模式似乎有效。 以下是javadoc的相关摘录,列出了所有可用的格式模式: letterdate或time组件演示示例 G 纪元 y 1996年;96 Y 2009年一周;09 M / L 年月日;7月;07 w 第27周 W 第二个月的一周 D 第189天 d 第10个月的一天 F 第2个月的星期几 E 星期二;星期二 u 周数1 a 上午/下午markertextpm H 小时(0-23)数字0 k 小时(1-24)数字24 K 上午/下午的小时数(0-11)数字0 h 上午/下午(1-12)时数12 m 30分钟 s 第二分钟55号 S 毫秒数字978 z 时区一般时区特定标准时间;公用电话;gmt-08:00 Z 时区FC 822时区-0800 X 时区ISO 8601时区-08-0800; -08:00 请注意,这些模式区分大小写,四个或更多字符的基于文本的模式表示完整的形式;否则,可使用缩写形式。例如。 MMMMM 或者更多是不必要的。 下面是一些有效的例子 SimpleDateFormat 到目前为止解析给定字符串的模式: 输入stringpattern2001.07.04 ad,时间:12:08:56 pdt yyyy.MM.dd G 'at' HH:mm:ss z 2001年7月4日,星期三 EEE, MMM d, ''yy 下午12:08 h:mm a 太平洋夏令时下午12点 hh 'o''clock' a, zzzz 下午0:08,pdt K:mm a, z 02001.07.04公元12:08下午 yyyyy.MMMM.dd GGG hh:mm aaa 2001年7月4日星期三12:08:56-0700 EEE, d MMM yyyy HH:mm:ss Z 010704120856-0700 yyMMddHHmmssZ 2001-07-04t12:08:56.235-0700 yyyy-MM-dd'T'HH:mm:ss.SSSZ 2001-07-04t12:08:56.235-07:00 yyyy-MM-dd'T'HH:mm:ss.SSSXXX 2001年-w27-3 YYYY-'W'ww-u 重要的一点是 SimpleDateFormat 不是线程安全的。换句话说,您不应该将它声明为静态变量或示例变量并将其赋值,然后从不同的方法/线程中重用它。您应该始终在本地范围内创建全新的方法。
注意:如果格式模式碰巧也包含时间部分,那么使用 LocalDateTime#parse(text, formatter) 而不是 LocalDate#parse(text, formatter) . 而且,如果格式模式碰巧也包含时区,那么使用 ZonedDateTime#parse(text, formatter) 相反。 以下是javadoc的相关摘录,列出了所有可用的格式模式: 符号含义表示示例 G eratextad公司;阿诺多米尼;一 u 2004年;04 y 2004年;04 D 第189天 M / L 月份编号/text7;07; 7月;七月;j d 每月10日 Q / q 四分之一数字/text3;03; 问题3;第三季度 Y 以周为基础的1996年;96 w 每周27 W 每月第4周 E 星期二;星期二;t型 e / c 本地化工作日编号/text2;02; 星期二;星期二;t型 F 每月第3周 a 上午下午 h 上午1点到下午12点(1-12)数字12 K 上午至下午(0-11)时数0 k 上午1点到下午2点(1-24)数字0 H 小时数(0-23)数字0 m 30分钟 s 分秒55 S 二次压裂分数978 A 毫秒数字1234 n 毫微秒数字987654321 N 纳米日数123400000 V 美国/洛杉矶时区;z-08:30 z 时区名称太平洋标准时间;pst公司 O 局部区域偏移ogmt+8;gmt+08:00;utc-08:00; X 零偏移xz的区域偏移'z'-08; -0830; -08:30; -083015; -08:30:15; x 区域偏移-x+0000-08; -0830; -08:30; -083015; -08:30:15; Z 区域偏移-z+0000-0800; -08:00; 请注意,对于更流行的模式,它有几个预定义的格式化程序。所以不是例如。 DateTimeFormatter.ofPattern("EEE, d MMM yyyy HH:mm:ss Z", Locale.ENGLISH); ,你可以用 DateTimeFormatter.RFC_1123_DATE_TIME . 这是可能的,因为它们是相反的 SimpleDateFormat ,线程安全。因此,如果必要的话,你也可以定义你自己的。 对于特定的输入字符串格式,不需要使用显式 DateTimeFormatter :标准iso 8601日期,如2016-09-26t17:44:57z,可以用 LocalDateTime#parse(text) 因为它已经使用了 ISO_LOCAL_DATE_TIME 格式化程序。同样地, LocalDate#parse(text) 解析不带时间组件的iso日期(请参见 ISO_LOCAL_DATE ),和 ZonedDateTime#parse(text) 解析添加了偏移量和时区的iso日期(请参见 ISO_ZONED_DATE_TIME ).
// if we 2nd even we have changed in pattern also it is not working please workout with 2nd
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("MMMM Q, yyyy", Locale.ENGLISH);
LocalDate date = LocalDate.parse(str, formatter);
// access date fields
int year = date.getYear(); // 2010
int day = date.getDayOfMonth(); // 2
Month month = date.getMonth(); // JANUARY
int monthAsInt = month.getValue(); // 1
All letters 'A' to 'Z' and 'a' to 'z' are reserved as pattern letters.
The following pattern letters are defined:
Symbol Meaning Presentation Examples
------ ------- ------------ -------
G era text AD; Anno Domini; A
u year year 2004; 04
y year-of-era year 2004; 04
D day-of-year number 189
M/L month-of-year number/text 7; 07; Jul; July; J
d day-of-month number 10
Q/q quarter-of-year number/text 3; 03; Q3; 3rd quarter
Y week-based-year year 1996; 96
w week-of-week-based-year number 27
W week-of-month number 4
E day-of-week text Tue; Tuesday; T
e/c localized day-of-week number/text 2; 02; Tue; Tuesday; T
F week-of-month number 3
a am-pm-of-day text PM
h clock-hour-of-am-pm (1-12) number 12
K hour-of-am-pm (0-11) number 0
k clock-hour-of-am-pm (1-24) number 0
H hour-of-day (0-23) number 0
m minute-of-hour number 30
s second-of-minute number 55
S fraction-of-second fraction 978
A milli-of-day number 1234
n nano-of-second number 987654321
N nano-of-day number 1234000000
V time-zone ID zone-id America/Los_Angeles; Z; -08:30
z time-zone name zone-name Pacific Standard Time; PST
O localized zone-offset offset-O GMT+8; GMT+08:00; UTC-08:00;
X zone-offset 'Z' for zero offset-X Z; -08; -0830; -08:30; -083015; -08:30:15;
x zone-offset offset-x +0000; -08; -0830; -08:30; -083015; -08:30:15;
Z zone-offset offset-Z +0000; -0800; -08:00;
6条答案
按热度按时间cygmwpex1#
这条路很难走
java.util.Date
自从Java1.1(1997)以来,setter方法就一直被弃用。只需使用SimpleDateFormat
使用与输入字符串匹配的格式模式。在“2010年1月2日”作为输入字符串的特定情况下:
“一月”是全文月份,所以使用
MMMM
它的模式“2”是一个月中较短的一天,所以使用
d
它的模式。“2010”是4位数的年份,所以使用
yyyy
它的模式。请注意显式
Locale
争论。如果您省略它,那么它将使用默认的语言环境,而不是输入字符串的月份名称中使用的英语。如果区域设置与输入字符串不匹配,那么您将得到一个java.text.ParseException
即使格式模式似乎有效。以下是javadoc的相关摘录,列出了所有可用的格式模式:
letterdate或time组件演示示例
G
纪元y
1996年;96Y
2009年一周;09M
/L
年月日;7月;07w
第27周W
第二个月的一周D
第189天d
第10个月的一天F
第2个月的星期几E
星期二;星期二u
周数1a
上午/下午markertextpmH
小时(0-23)数字0k
小时(1-24)数字24K
上午/下午的小时数(0-11)数字0h
上午/下午(1-12)时数12m
30分钟s
第二分钟55号S
毫秒数字978z
时区一般时区特定标准时间;公用电话;gmt-08:00Z
时区FC 822时区-0800X
时区ISO 8601时区-08-0800; -08:00请注意,这些模式区分大小写,四个或更多字符的基于文本的模式表示完整的形式;否则,可使用缩写形式。例如。
MMMMM
或者更多是不必要的。下面是一些有效的例子
SimpleDateFormat
到目前为止解析给定字符串的模式:输入stringpattern2001.07.04 ad,时间:12:08:56 pdt
yyyy.MM.dd G 'at' HH:mm:ss z
2001年7月4日,星期三EEE, MMM d, ''yy
下午12:08h:mm a
太平洋夏令时下午12点hh 'o''clock' a, zzzz
下午0:08,pdtK:mm a, z
02001.07.04公元12:08下午yyyyy.MMMM.dd GGG hh:mm aaa
2001年7月4日星期三12:08:56-0700EEE, d MMM yyyy HH:mm:ss Z
010704120856-0700yyMMddHHmmssZ
2001-07-04t12:08:56.235-0700yyyy-MM-dd'T'HH:mm:ss.SSSZ
2001-07-04t12:08:56.235-07:00yyyy-MM-dd'T'HH:mm:ss.SSSXXX
2001年-w27-3YYYY-'W'ww-u
重要的一点是SimpleDateFormat
不是线程安全的。换句话说,您不应该将它声明为静态变量或示例变量并将其赋值,然后从不同的方法/线程中重用它。您应该始终在本地范围内创建全新的方法。java 8更新
如果您碰巧使用Java8或更新版本,那么使用
DateTimeFormatter
(同样在这里,单击链接以查看所有预定义的格式化程序和可用的格式模式;教程在这里提供)。这个新api的灵感来自jodatime。注意:如果格式模式碰巧也包含时间部分,那么使用
LocalDateTime#parse(text, formatter)
而不是LocalDate#parse(text, formatter)
. 而且,如果格式模式碰巧也包含时区,那么使用ZonedDateTime#parse(text, formatter)
相反。以下是javadoc的相关摘录,列出了所有可用的格式模式:
符号含义表示示例
G
eratextad公司;阿诺多米尼;一u
2004年;04y
2004年;04D
第189天M
/L
月份编号/text7;07; 7月;七月;jd
每月10日Q
/q
四分之一数字/text3;03; 问题3;第三季度Y
以周为基础的1996年;96w
每周27W
每月第4周E
星期二;星期二;t型e
/c
本地化工作日编号/text2;02; 星期二;星期二;t型F
每月第3周a
上午下午h
上午1点到下午12点(1-12)数字12K
上午至下午(0-11)时数0k
上午1点到下午2点(1-24)数字0H
小时数(0-23)数字0m
30分钟s
分秒55S
二次压裂分数978A
毫秒数字1234n
毫微秒数字987654321N
纳米日数123400000V
美国/洛杉矶时区;z-08:30z
时区名称太平洋标准时间;pst公司O
局部区域偏移ogmt+8;gmt+08:00;utc-08:00;X
零偏移xz的区域偏移'z'-08; -0830; -08:30; -083015; -08:30:15;x
区域偏移-x+0000-08; -0830; -08:30; -083015; -08:30:15;Z
区域偏移-z+0000-0800; -08:00;请注意,对于更流行的模式,它有几个预定义的格式化程序。所以不是例如。
DateTimeFormatter.ofPattern("EEE, d MMM yyyy HH:mm:ss Z", Locale.ENGLISH);
,你可以用DateTimeFormatter.RFC_1123_DATE_TIME
. 这是可能的,因为它们是相反的SimpleDateFormat
,线程安全。因此,如果必要的话,你也可以定义你自己的。对于特定的输入字符串格式,不需要使用显式
DateTimeFormatter
:标准iso 8601日期,如2016-09-26t17:44:57z,可以用LocalDateTime#parse(text)
因为它已经使用了ISO_LOCAL_DATE_TIME
格式化程序。同样地,LocalDate#parse(text)
解析不带时间组件的iso日期(请参见ISO_LOCAL_DATE
),和ZonedDateTime#parse(text)
解析添加了偏移量和时区的iso日期(请参见ISO_ZONED_DATE_TIME
).ktca8awb2#
啊,是的,又是关于java日期的讨论。为了处理日期操作,我们使用日期、日历、gregoriancalendar和simpledateformat。例如,使用一月日期作为输入:
然后你可以用以下方法来控制它:
0aydgbwb3#
dsf9zpds4#
使用Java8,我们得到了一个新的日期/时间api(JSR310)。
可以使用以下方法在java 8中解析日期,而不依赖于joda time:
localdate是表示日期(不含时间)的标准Java8类。如果要解析包含日期和时间信息的值,应该使用localdatetime。对于带有时区的值,请使用zoneddatetime。两者都提供了
parse()
方法类似于LocalDate
:datetimeformatter javadoc中的格式化字符列表:
kokeuurv5#
虽然有些答案在技术上是正确的,但并不可取。
众所周知,java.util.date&calendar类非常麻烦。由于设计和实现中的缺陷,请避免它们。幸运的是,我们可以选择另外两个优秀的日期时间库:
乔达时间
这个流行的开源免费库可以跨多个版本的java使用。在stackoverflow上可以找到许多使用它的例子。阅读其中的一些将有助于你快速地了解情况。
java.time.*包
这组新类的灵感来自joda time,并由jsr 310定义。这些类内置于Java8中。正在进行一个项目,将这些类向后移植到Java7,但oracle不支持这种向后移植。
正如克里斯托弗·Json(kristopher johnson)在对这个问题的评论中正确指出的那样,其他答案忽略了以下重要问题:
一天中的时间
日期既有日期部分,也有时间部分)
时区
一天的开始取决于时区。如果没有指定时区,则应用jvm的默认时区。这意味着在其他计算机上运行或使用修改的时区设置时,代码的行为可能会更改。可能不是你想要的。
区域设置
区域设置的语言指定如何解释解析过程中遇到的单词(月和日的名称)(balusc的答案可以很好地处理这个问题。)另外,在生成日期时间的字符串表示形式时,区域设置会影响某些格式化程序的输出。
乔达时间
接下来是一些关于乔达时间的笔记。
时区
在joda time中,datetime对象真正知道自己分配的时区。这与java.util.date类形成了对比,后者似乎有时区,但没有时区。
请注意下面的示例代码中,我们如何将时区对象传递给解析字符串的格式化程序。该时区用于将日期时间解释为发生在该时区中。因此,您需要考虑并确定由该字符串输入表示的时区。
由于输入字符串中没有时间部分,joda time将指定时区当天的第一个时刻指定为一天中的时间。通常这意味着
00:00:00
但并非总是如此,因为夏令时(dst)或其他异常情况。顺便说一下,您可以通过调用withTimeAtStartOfDay
.格式化程序模式
格式化程序模式中使用的字符在joda time中与java.util.date/calendar中的字符相似,但并不完全相同。仔细阅读文件。
不变性
在joda时代,我们通常使用不可变类。我们调用的方法不是修改现有的日期时间对象,而是基于另一个对象创建一个新的新示例,除了需要修改的地方外,复制了大多数方面。一个例子是调用
withZone
在下面最后一行。不变性有助于使joda time非常线程安全,还可以使某些工作更加清晰。转换
您将需要java.util.date对象与其他不了解joda时间对象的类/框架一起使用。幸运的是,它很容易来回移动。
从java.util.date对象(此处命名为
date
)给乔达时间日期时间…从joda time转到java.util.date对象的另一个方向…
样本代码
运行时…
ne5o7dgx6#
在处理SimpleDataFormat类时,重要的是要记住date不是线程安全的,不能与多个线程共享一个date对象。
“m”和“m”之间也有很大的区别,小格表示分钟,大写字母表示月份。与“d”和“d”相同。这会导致