日期格式转换java_Java中日期_格式转换

Java中日期格式转换

/**

* 字符串转换为java.util.Date

* 支持格式为 yyyy.MM.dd G 'at' hh:mm:ss z 如 '2002-1-1 AD at 22:10:59 PSD'

* yy/MM/dd HH:mm:ss 如 '2002/1/1 17:55:00'

* yy/MM/dd HH:mm:ss pm 如 '2002/1/1 17:55:00 pm'

* yy-MM-dd HH:mm:ss 如 '2002-1-1 17:55:00'

* yy-MM-dd HH:mm:ss am 如 '2002-1-1 17:55:00 am'

* @param time String 字符串

* @return Date 日期

*/

public static Date stringToDate(String time){

SimpleDateFormat formatter;

int tempPos=time.indexOf("AD") ;

time=time.trim() ;

formatter = new SimpleDateFormat ("yyyy.MM.dd G 'at' hh:mm:ss z");

if(tempPos>-1){

time=time.substring(0,tempPos)+

"公元"+time.substring(tempPos+"AD".length());//china

formatter = new SimpleDateFormat ("yyyy.MM.dd G 'at' hh:mm:ss z");

}

tempPos=time.indexOf("-");

if(tempPos>-1&&(time.indexOf(" ")<0)){

formatter = new SimpleDateFormat ("yyyyMMddHHmmssZ");

}

else if((time.indexOf("/")>-1) &&(time.indexOf(" ")>-1)){

formatter = new SimpleDateFormat ("yyyy/MM/dd HH:mm:ss");

}

else if((time.indexOf("-")>-1) &&(time.indexOf(" ")>-1)){

formatter = new SimpleDateFormat ("yyyy-MM-dd HH:mm:ss");

}

else if((time.indexOf("/")>-1) &&(time.indexOf("am")>-1) ||(time.indexOf("pm")>-1)){

formatter = new SimpleDateFormat ("yyyy-MM-dd KK:mm:ss a");

}

else if((time.indexOf("-")>-1) &&(time.indexOf("am")>-1) ||(time.indexOf("pm")>-1)){

formatter = new SimpleDateFormat ("yyyy-MM-dd KK:mm:ss a");

}

ParsePosition pos = new ParsePosition(0);

java.util.Date ctime = formatter.parse(time, pos);

return ctime;

}

/**

* 将java.util.Date 格式转换为字符串格式'yyyy-MM-dd HH:mm:ss'(24小时制)

* 如Sat May 11 17:24:21 CST 2002 to '2002-05-11 17:24:21'

* @param time Date 日期

* @return String   字符串

*/

public static String dateToString(Date time){

SimpleDateFormat formatter;

formatter = new SimpleDateFormat ("yyyy-MM-dd HH:mm:ss");

String ctime = formatter.format(time);

return ctime;

}

/**

* 将java.util.Date 格式转换为字符串格式'yyyy-MM-dd HH:mm:ss a'(12小时制)

* 如Sat May 11 17:23:22 CST 2002 to '2002-05-11 05:23:22 下午'

* @param time Date 日期

* @param x int 任意整数如:1

* @return String 字符串

*/

public static String dateToString(Date time,int x){

SimpleDateFormat formatter;

formatter = new SimpleDateFormat ("yyyy-MM-dd KK:mm:ss a");

String ctime = formatter.format(time);

return ctime;

}

/**

*取系统当前时间:返回只值为如下形式

*2002-10-30 20:24:39

* @return String

*/

public static String Now(){

return dateToString(new Date());

}

/**

*取系统当前时间:返回只值为如下形式

*2002-10-30 08:28:56 下午

*@param hour 为任意整数

*@return String

*/

public static String Now(int hour){

return dateToString(new Date(),hour);

}

/**

*取系统当前时间:返回值为如下形式

*2002-10-30

*@return String

*/

public static String getYYYY_MM_DD(){

return dateToString(new Date()).substring(0,10);

}

/**

*取系统给定时间:返回值为如下形式

*2002-10-30

*@return String

*/

public static String getYYYY_MM_DD(String date){

return date.substring(0,10);

}

public static String getHour(){

SimpleDateFormat formatter;

formatter = new SimpleDateFormat ("H");

String ctime = formatter.format(new Date());

return ctime;

}

public static String getDay(){

SimpleDateFormat formatter;

formatter = new SimpleDateFormat ("d");

String ctime = formatter.format(new Date());

return ctime;

}

public static String getMonth(){

SimpleDateFormat formatter;

formatter = new SimpleDateFormat ("M");

String ctime = formatter.format(new Date());

return ctime;

}

public static String getYear(){

SimpleDateFormat formatter;

formatter = new SimpleDateFormat ("yyyy");

String ctime = formatter.format(new Date());

return ctime;

}

public static String getWeek(){

SimpleDateFormat formatter;

formatter = new SimpleDateFormat ("E");

String ctime = formatter.format(new Date());

return ctime;

}

在jsp页面中的日期格式和sqlserver中的日期格式不一样,怎样统一?

在页面上显示输出时,用下面的函数处理一下

public class DateUtil(){

public static String fmtShortEnu(Date myDate) {

SimpleDateFormat formatter = new SimpleDateFormat("yyyy/MM/dd");

String strDate = formatter.format(myDate);

return strDate;

}

}

new java.text.SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

new java.text.SimpleDateFormat("yyyy-MM-dd")

建议还是把sqlserver的字段类型改成varchar的吧,用字符串处理可以完全按照自己的意愿处理,没有特殊的需求,不要使用date型

字串日期格式转换

用的API是SimpleDateFormat,它是属於java.text.SimpleDateFormat,所以请记得import进来!

用法:

SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

这一行最重要,它确立了转换的格式,yyyy是完整的西元年,MM是月份,dd是日期, 至於HH:mm:ss就不需要我再解释了吧!

ps:为什麽有的格式大写,有的格式小写,那是怕避免混淆,例如MM是月份,mm是分;HH是24小时制,而hh是12小时制

1.字串转日期:

2002-10-8 15:30:22要把它转成日期,可以用

Date date=sdf.parse("2002-10-8 15:30:22");

2.日期转字串

假如把今天的日期转成字串可用

String datestr=sdf.format(new Date());

这个字串的内容便类似2002-10-08 14:55:38

透过这个API我们便可以随心所欲的将日期转成我们想要的字串格式,例如希望将日期输出成2002年10月08日,

我们可以这麽写:

SimpleDateFormat sdf=new SimpleDateFormat("yyyy年MM月dd日");

String datestr=sdf.format(new Date());

datestr便会依照我们设定的格式输出

//对日期格式的转换成("yyyy-MM-dd")格式的方法

public java.sql.Date Convert(String str)

{

java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat("yyyy-MM-dd");

try

{

java.util.Date d = sdf.parse(str);

java.sql.Date d1 = new java.sql.Date(d.getTime());

return d1;

}

catch(Exception ex)

{

ex.printStackTrace();

return null;

}

}

应用如下:

ctmt.setDate(7,this.Convert(info.getManBirth())); // @DATETIME

常用日期问题集锦

1、获取服务器端当前日期:

Date myDate = new Date();

%>

2、获取当前年、月、日:

Date myDate = new Date();

int thisYear = myDate.getYear() + 1900;//thisYear = 2003

int thisMonth = myDate.getMonth() + 1;//thisMonth = 5

int thisDate = myDate.getDate();//thisDate = 30

%>

3、按本地时区输出当前日期

Date myDate = new Date();

out.println(myDate.toLocaleString());

%>

输出结果为:

2003-5-30

4、获取数据库中字段名为”publish_time“、类型为Datetime的值

...连接数据库...

ResultSet rs = ...

Date sDate = rs.getDate("publish_time");

%>

[code]

5、按照指定格式打印日期

[code]

Date dNow = new Date();

SimpleDateFormat formatter = new SimpleDateFormat("E yyyy.MM.dd 'at' hh:mm:ss a zzz");

out.println("It is " + formatter.format(dNow));

%>

输出的结果为:

It is 星期五 2003.05.30 at 11:30:46 上午 CST

(更为详尽的格式符号请参看SimpleDateFormat类)

6、将字符串转换为日期

String input = "1222-11-11";

SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd");

Date t = null;

try{

t = formatter.parse(input);

out.println(t);

}catch(ParseException e){

out.println("unparseable using " + formatter);

}

%>

输出结果为:

Fri Nov 11 00:00:00 CST 1222

7、计算日期之间的间隔

String input = "2003-05-01";

SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd");

Date d1 = null;

try{

d1 = formatter.parse(input);

}catch(ParseException e){

out.println("unparseable using " + formatter);

}

Date d2 = new Date();

long diff = d2.getTime() - d1.getTime();

out.println("Difference is " + (diff/(1000*60*60*24)) + " days.");

%>

输出结果为:

Difference is 29 days.

8、日期的加减运算

方法:用Calendar类的add()方法

Calendar now = Calendar.getInstance();

SimpleDateFormat formatter = new SimpleDateFormat("E yyyy.MM.dd 'at' hh:mm:ss a zzz");

out.println("It is now " + formatter.format(now.getTime()));

now.add(Calendar.DAY_OF_YEAR,-(365*2));

out.println("
");

out.println("Two years ago was " + formatter.format(now.getTime()));

%>

输出结果为:

It is now 星期五 2003.05.30 at 01:45:32 下午 CST

Two years ago was 星期三 2001.05.30 at 01:45:32 下午 CST

9、比较日期

方法:用equals()、before()、after()方法

DateFormat df = new SimpleDateFormat("yyy-MM-dd");

Date d1 = df.parse("2000-01-01");

Date d2 = df.parse("1999-12-31");

String relation = null;

if(d1.equals(d2))

relation = "the same date as";

else if(d1.before(d2))

relation = "before";

else

relation = "after";

out.println(d1 +" is " + relation + ' ' + d2);

%>

输出结果为:

Sat Jan 01 00:00:00 CST 2000 is after Fri Dec 31 00:00:00 CST 1999

10、记录一件事所花费的时间

方法:调用两次System.getTimeMillis()方法,求差值

long t0,t1;

t0 = System.currentTimeMillis();

out.println("Cyc starts at " + t0);

int k = 0;

for(int i =0;i<100000;i++){

k += i;

}

t1 = System.currentTimeMillis();

out.println("
");

out.println("Cyc ends at " + t1);

out.println("
");

out.println("This run took " + (t1-t0) + "ms.");

%>

输出结果为:

Cyc starts at 1054275312432

Cyc ends at 1054275312442

This run took 10ms.

其它:如何格式化小数

DecimalFormat df = new DecimalFormat(",###.00");

double aNumber = 33665448856.6568975;

String result = df.format(aNumber);

out.println(result);

%>

输出结果为:

33,665,448,856.66

======================

日期比较:

在JAVA中日期的计算与比较可以使用Date和DateFormat来解决,下面是一段示例代码:

import java.text.*;

import java.util.*;

public class Test{

public static void main(String[] args){

try{

Date date=new Date();

DateFormat df=DateFormat.getDateTimeInstance();

String now=df.format(date);

System.out.println("现在时间:"+now);

System.out.println("现在时间是否在16:00之前:"+date.before(df.parse("2004-12-24 16:00:00")));

}

catch(ParseException e){System.out.print(e.getMessage());

}

}

}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值