Date和Calendar用法.doc_第1页
Date和Calendar用法.doc_第2页
Date和Calendar用法.doc_第3页
Date和Calendar用法.doc_第4页
Date和Calendar用法.doc_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1.计算某一月份的最大天数Calendar time=Calendar.getInstance();time.clear();time.set(Calendar.YEAR,year); /year 为 int time.set(Calendar.MONTH,i-1);/注意,Calendar对象默认一月为0 int day=time.getActualMaximum(Calendar.DAY_OF_MONTH);/本月份的天数注:在使用set方法之前,必须先clear一下,否则很多信息会继承自系统当前时间2.Calendar和Date的转化(1) Calendar转化为DateCalendar cal=Calendar.getInstance();Date date=cal.getTime();(2) Date转化为CalendarDate date=new Date();Calendar cal=Calendar.getInstance();cal.setTime(date);3.格式化输出日期时间 (这个用的比较多)Date date=new Date();SimpleDateFormat df=new SimpleDateFormat(yyyy-MM-dd hh:mm:ss);String time=df.format(date);System.out.println(time);4.计算一年中的第几星期(1)计算某一天是一年中的第几星期Calendar cal=Calendar.getInstance();cal.set(Calendar.YEAR, 2006);cal.set(Calendar.MONTH, 8);cal.set(Calendar.DAY_OF_MONTH, 3);int weekno=cal.get(Calendar.WEEK_OF_YEAR);(2)计算一年中的第几星期是几号SimpleDateFormat df=new SimpleDateFormat(yyyy-MM-dd);Calendar cal=Calendar.getInstance();cal.set(Calendar.YEAR, 2006);cal.set(Calendar.WEEK_OF_YEAR, 1);cal.set(Calendar.DAY_OF_WEEK, Calendar.MONDAY);System.out.println(df.format(cal.getTime();输出:2006-01-025.add()和roll()的用法(不太常用)(1)add()方法SimpleDateFormat df=new SimpleDateFormat(yyyy-MM-dd);Calendar cal=Calendar.getInstance();cal.set(Calendar.YEAR, 2006);cal.set(Calendar.MONTH, 8);cal.set(Calendar.DAY_OF_MONTH, 3);cal.add(Calendar.DATE, -4);Date date=cal.getTime();System.out.println(df.format(date);cal.add(Calendar.DATE, 4);date=cal.getTime();System.out.println(df.format(date);输出: 2006-08-30 2006-09-03(2)roll方法cal.set(Calendar.YEAR, 2006);cal.set(Calendar.MONTH, 8);cal.set(Calendar.DAY_OF_MONTH, 3);cal.roll(Calendar.DATE, -4);date=cal.getTime();System.out.println(df.format(date);cal.roll(Calendar.DATE, 4);date=cal.getTime();System.out.println(df.format(date);输出: 2006-09-29 2006-09-03可见,roll()方法在本月内循环,一般使用add()方法;6.计算两个任意时间中间的间隔天数(这个比较常用)(1)传进Calendar对象 public int getIntervalDays(Calendar startday,Calendar endday). if(startday.after(endday). Calendar cal=startday; startday=endday; endday=cal; long sl=startday.getTimeInMillis(); long el=endday.getTimeInMillis(); long ei=el-sl; return (int)(ei/(1000*60*60*24); (2)传进Date对象 public int getIntervalDays(Date startday,Date endday). if(startday.after(endday). Date cal=startday; startday=endday; endday=cal; long sl=startday.getTime(); long el=endday.getTime(); long ei=el-sl; return (int)(ei/(1000*60*60*24); (3)改进精确计算相隔天数的方法 public int getDaysBetween (Calendar d1, Calendar d2) . if (d1.after(d2) . java.util.Calendar swap = d1; d1 = d2; d2 = swap; int days = d2.get(Calendar.DAY_OF_YEAR) - d1.get(Calendar.DAY_OF_YEAR); int y2 = d2.get(Calendar.YEAR); if (d1.get(Calendar.YEAR) != y2) . d1 = (Calendar) d1.clone(); do . days += d1.getActualMaximum(Calendar.DAY_OF_YEAR);/得到当年的实际天数 d1.add(Calendar.YEAR, 1); while (d1.get(Calendar.YEAR) != y2); return days; 注意:通过上面的方法可以衍生出求任何时间,如要查出邮箱三周之内收到的邮件(得到当前系统时间再得到三周前时间)用收件的时间去匹配 最好装化成 long去比较如:1年前日期(注意毫秒的转换) java.util.Date myDate=new java.util.Date(); long myTime=(myDate.getTime()/1000)-60*60*24*365; myDate.setTime(myTime*1000); String mDate=formatter.format(myDate);7. String 和 Date ,Long 之间相互转换 (最常用)字符串转化成时间类型(字符串可以是任意类型,只要和SimpleDateFormat中的格式一致即可)通常我们取时间跨度的时候,会substring出具体时间long比较java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat(M/dd/yyyy hh:mm:ss a,java.util.Locale.US);java.util.Date d = sdf.parse(5/13/2003 10:31:37 AM);long dvalue=d.getTime();SimpleDateFormat formatter = new SimpleDateFormat(yyyy-MM-dd HH:mm:ss);String mDateTime1=formatter.format(d);8. 通过时间求时间年月周求日期SimpleDateFormat formatter2 = new SimpleDateFormat(yyyy-MM F E);java.util.Date date2= formatter2.parse(2003-05 5 星期五);SimpleDateFormat formatter3 = new SimpleDateFormat(yyyy-MM-dd);String mydate2=formatter3.format(date2);求是星期几mydate= myFormatter.parse(2001-1-1);SimpleDateFormat formatter4 = new SimpleDateFormat(E);String mydate3=formatter4.format(mydate);9. java 和 具体的数据库结合在开发web应用中,针对不同的数据库日期类型,我们需要在我们的程序中对日期类型做各种不同的转换。若对应数据库数据是oracle的Date类型,即只需要年月日的,可以选择使用java.sql.Date类型,若对应的是MSsqlserver 数据库的DateTime类型,即需要年月日时分秒的,选择java.sql.Timestamp类型你可以使用dateFormat定义时间日期的格式,转一个字符串即可class Datetest*method 将字符串类型的日期转换为一个timestamp(时间戳记java.sql.Timestamp)*param dateString 需要转换为timestamp的字符串*return dataTime timestamppublic final static java.sql.Timestamp string2Time(String dateString) throws java.text.ParseException DateFormat dateFormat; dateFormat = new SimpleDateFormat(yyyy-MM-dd kk:mm:ss.SSS, Locale.ENGLISH);/设定格式 /dateFormat = new SimpleDateFormat(yyyy-MM-dd kk:mm:ss, Locale.ENGLISH); dateFormat.setLenient(false); java.util.Date timeDate = dateFormat.parse(dateString);/util类型 /Timestamp类型,timeDate.getTime()返回一个long型 java.sql.Timestamp dateTime = new java.sql.Timestamp(timeDate.getTime(); return dateTime;*method 将字符串类型的日期转换为一个Date(java.sql.Date)*param dateString 需要转换为Date的字符串*return dataTime Datepublic final static java.sql.Date string2Date(String dateString) throws java.lang.Exception DateFormat dateFormat; dateFormat = new SimpleDateFormat(yyyy-MM-dd, Locale.ENGLISH); dateFormat.setLenient(false); java.util.Date timeDate = dateFormat.parse(dateString);/util类型 java.sql.Date dateTime = new java.sql.Date(timeDate.getTime();/sql类型 return dateTime;public static void main(String args)Date da = new Date();注意:这个地方da.getTime()得到的是一个long型的值System.out.println(da.getTime();由日期date转换为timestamp第一种方法:使用new Timestamp(long)Timestamp t = new Timestamp(new Date().getTime();System.out.println(t);第二种方法:使用Timestamp(int year,int month,int date,int hour,int minute,int second,int nano)Timestamp tt = new Timestamp(Calendar.getInstance().get( Calendar.Y

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论