日期类的加减及java中所以日期类的操作算法大全
1.计算某一月份的最大天数
Calendar time=Calendar.getInstance();2
time.clear();3
time.set(Calendar.YEAR,year); //year 为 int 4
time.set(Calendar.MONTH,i-1);//注意,Calendar对象默认一月为0 5
int day=time.getActualMaximum(Calendar.DAY_OF_MONTH);//本月份的天数注:在使用set方法之前,必须先clear一下,否则很多信息会继承自系统当前时间
2.Calendar和Date的转化
(1) Calendar转化为Date
Calendar cal=Calendar.getInstance();
Date date=cal.getTime();(2) Date转化为Calendar
Date date=new Date();
Calendar cal=Calendar.getInstance();
cal.setTime(date);3.格式化输出日期时间 (这个用的比较多)
其一
Date date=new Date();2
SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");3
String time=df.format(date);4
System.out.println(time);//2008-10-27 08:52:32其二
Calendar c = Calendar.getInstance();2
System.out.println(c.getTime());//Mon Oct 27 08:51:21 CST 20083
SimpleDateFormat simpleDateTimeFormat = new SimpleDateFormat(" yyyy-MM-dd HH:mm:ss ");4
c = Calendar.getInstance(Locale.CHINESE);5
System.out.println(simpleDateTimeFormat.format(c.getTime()));// 2008-10-27 08:51:21 4.计算一年中的第几星期
(1)计算某一天是一年中的第几星期
Calendar cal=Calendar.getInstance();2
cal.set(Calendar.YEAR, 2006);3
cal.set(Calendar.MONTH, 8);4
cal.set(Calendar.DAY_OF_MONTH, 3);5
int weekno=cal.get(Calendar.WEEK_OF_YEAR);(2)计算一年中的第几星期是几号
SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd");2
Calendar cal=Calendar.getInstance();3
cal.set(Calendar.YEAR, 2006);4
cal.set(Calendar.WEEK_OF_YEAR, 1);5
cal.set(Calendar.DAY_OF_WEEK, Calendar.MONDAY);6
System.out.println(df.format(cal.getTime()));输出:
2006-01-02
5.add()和roll()的用法(不太常用)
(1)add()方法
SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd");2
Calendar cal=Calendar.getInstance();3
cal.set(Calendar.YEAR, 2006);4
cal.set(Calendar.MONTH, 8);5
cal.set(Calendar.DAY_OF_MONTH, 3);6
cal.add(Calendar.DATE, -4);7
Date date=cal.getTime();8
System.out.println(df.format(date));9
cal.add(Calendar.DATE, 4);10
date=cal.getTime();11
System.out.println(df.format(date));输出:
2006-08-30
2006-09-03
(2)roll方法
cal.set(Calendar.YEAR, 2006);2
cal.set(Calendar.MONTH, 8);3
cal.set(Calendar.DAY_OF_MONTH, 3);4
cal.roll(Calendar.DATE, -4);5
date=cal.getTime();6
System.out.println(df.format(date));7
cal.roll(Calendar.DATE, 4);8
date=cal.getTime();9
System.out.println(df.format(date));输出:
2006-09-29
2006-09-03
可见,roll()方法在本月内循环,一般使用add()方法;
6.计算两个任意时间中间的间隔天数(这个比较常用)
(1)传进Calendar对象
public int getIntervalDays(Calendar startday,Calendar endday)
{ 2
if(startday.after(endday))
{3
Calendar cal=startday;4
startday=endday;5
endday=cal;6
} 7
long sl=startday.getTimeInMillis();8
long el=endday.getTimeInMillis();9
10
long ei=el-sl; 11
return (int)(ei/(1000*60*60*24));12
}13

(2)传进Date对象
public int getIntervalDays(Date startday,Date endday)
{ 2
if(startday.after(endday))
{3
Date cal=startday;4
startday=endday;5
endday=cal;6
} 7
long sl=startday.getTime();8
long el=endday.getTime(); 9
long ei=el-sl; 10
return (int)(ei/(1000*60*60*24));11
}(3)改进精确计算相隔天数的方法
public int getDaysBetween (Calendar d1, Calendar d2)
{2
if (d1.after(d2))
{ 3
java.util.Calendar swap = d1;4
d1 = d2;5
d2 = swap;6
}7
int days = d2.get(Calendar.DAY_OF_YEAR) - d1.get(Calendar.DAY_OF_YEAR);8
int y2 = d2.get(Calendar.YEAR);9
if (d1.get(Calendar.YEAR) != y2)
{10
d1 = (Calendar) d1.clone();11
do
{12
days += d1.getActualMaximum(Calendar.DAY_OF_YEAR);//得到当年的实际天数13
d1.add(Calendar.YEAR, 1);14
} while (d1.get(Calendar.YEAR) != y2);15
}16
return days;17
}18

注意:通过上面的方法可以衍生出求任何时间,如要查出邮箱三周之内收到的邮件(得到当前系统时间-再得到三周前时间)用收件的时间去匹配 最好装化成 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);2
java.util.Date d = sdf.parse("5/13/2003 10:31:37 AM");3
long dvalue=d.getTime();4
SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");5
String mDateTime1=formatter.format(d);8. 通过时间求时间
年月周求日期
SimpleDateFormat formatter2 = new SimpleDateFormat("yyyy-MM F E");2
java.util.Date date2= formatter2.parse("2003-05 5 星期五");3
SimpleDateFormat formatter3 = new SimpleDateFormat("yyyy-MM-dd");4
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{2
*method 将字符串类型的日期转换为一个timestamp(时间戳记java.sql.Timestamp)3
*@param dateString 需要转换为timestamp的字符串4
*@return dataTime timestamp5

6
public final static java.sql.Timestamp string2Time(String dateString)7
throws java.text.ParseException {8
DateFormat dateFormat;9
dateFormat = new SimpleDateFormat("yyyy-MM-dd kk:mm:ss.SSS", Locale.ENGLISH);//设定格式10
//dateFormat = new SimpleDateFormat("yyyy-MM-dd kk:mm:ss", Locale.ENGLISH);11
dateFormat.setLenient(false);12
java.util.Date timeDate = dateFormat.parse(dateString);//util类型13
java.sql.Timestamp dateTime = new java.sql.Timestamp(timeDate.getTime());//Timestamp类型,timeDate.getTime()返回一个long型14
return dateTime;15
}16

17
*method 将字符串类型的日期转换为一个Date(java.sql.Date)18
*@param dateString 需要转换为Date的字符串19
*@return dataTime Date20

21
public final static java.sql.Date string2Date(String dateString)22
throws java.lang.Exception {23
DateFormat dateFormat;24
dateFormat = new SimpleDateFormat("yyyy-MM-dd", Locale.ENGLISH);25
dateFormat.setLenient(false);26
java.util.Date timeDate = dateFormat.parse(dateString);//util类型27
java.sql.Date dateTime = new java.sql.Date(timeDate.getTime());//sql类型28
return dateTime;29
}30

31
public static void main(String[] args){32
Date da = new Date();33
注意:这个地方da.getTime()得到的是一个long型的值34
System.out.println(da.getTime());35

36
由日期date转换为timestamp37

38
第一种方法:使用new Timestamp(long)39
Timestamp t = new Timestamp(new Date().getTime());40
System.out.println(t);41

42
第二种方法:使用Timestamp(int year,int month,int date,int hour,int minute,int second,int nano)43
Timestamp tt = new Timestamp(Calendar.getInstance().get(44
Calendar.YEAR) - 1900, Calendar.getInstance().get(45
Calendar.MONTH), Calendar.getInstance().get(46
Calendar.DATE), Calendar.getInstance().get(47
Calendar.HOUR), Calendar.getInstance().get(48
Calendar.MINUTE), Calendar.getInstance().get(49
Calendar.SECOND), 0);50
System.out.println(tt);51

52
try {53
String sToDate = "2005-8-18";//用于转换成java.sql.Date的字符串54
String sToTimestamp = "2005-8-18 14:21:12.123";//用于转换成java.sql.Timestamp的字符串55
Date date1 = string2Date(sToDate);56
Timestamp date2 = string2Time(sToTimestamp);57
System.out.println("Date:"+date1.toString());//结果显示58
System.out.println("Timestamp:"+date2.toString());//结果显示59
}catch(Exception e) {60
e.printStackTrace();61
}62
}63
} 64

日期类的加减及java中所以日期类的操作算法大全的更多相关文章
- Java中的日期操作
在日志中常用的记录当前时间及程序运行时长的方法: public void inject(Path urlDir) throws Exception { SimpleDateFormat sdf = n ...
- Java中的日期操作 分类: B1_JAVA 2015-02-16 17:55 6014人阅读 评论(0) 收藏
在日志中常用的记录当前时间及程序运行时长的方法: public void inject(Path urlDir) throws Exception { SimpleDateFormat sdf = n ...
- java中基于TaskEngine类封装实现定时任务
主要包括如下几个类: 文章标题:java中基于TaskEngine类封装实现定时任务 文章地址: http://blog.csdn.net/5iasp/article/details/10950529 ...
- Java基础(43):Java中的Object类与其方法(转)
Object类 java.lang.Object java.lang包在使用的时候无需显示导入,编译时由编译器自动导入. Object类是类层次结构的根,Java中所有的类从根本上都继承自这个类. O ...
- Java中的日期处理类
在Java中可以使用Date类和Calendar类来处理日期 但是Date类很多方法都过时了,推荐使用Canlendar类来处理日期,并对日期的格式化做了介绍.下面的部分将会逐一介绍 Date类 Ja ...
- Java中的日期表示类
一.概述 Java中的日期类设计的比较失败,刚开始使用Date来计算时间,后来大部分Date类的方法都过时了:想用Calendar类代替Date类,然而Calendar类也是不尽如人意.下面简单介绍下 ...
- Java中时间日期格式化
1.与日期时间相关的类: 第一:java.util.Date; 将时间作为一个整体使用.处理时,使用Date类较为简便 第二:j ...
- 填坑:Java 中的日期转换
我们之前讨论过时间,在Java 中有一些方法会出现横线?比如Date 过期方法. 参考文章:知识点:java一些方法会有横线?以Date 过期方法为例 Java中的日期和时间处理方法 Date类(官方 ...
- java中的日期处理
学习Java日期处理,看见这一篇比较详细,转载之. 转自:http://www.cnblogs.com/hqr9313/archive/2012/04/19/2458221.html 时间日期1) ...
随机推荐
- Ubuntu下面网络固定ip
https://jingyan.baidu.com/article/e5c39bf5bbe0e739d7603396.html
- samtools 的应用
1)sam转bam samtools view -bS in.sam > in.bam -b 意思使输出使BAM format -S 意思使输入使SAM,如果@SQ 缺剩, 要写-t
- 转-git 配置用户名和邮箱
原址:http://www.cnblogs.com/fsong/p/5540840.html 在安装了git for windows之后,个人总是忘记配置git config的命令,以此记录一下: 配 ...
- 【英宝通Unity4.0公开课学习 】(五)47讲到75讲
不知不觉今天都已经看了快30讲了,虽然很想快马加鞭地将后面的内容看完,但为了学习的质量,还是挺下来写一篇blog :) 这两天有些昏昏沉沉的,但感觉生活还安排得不错,原因找去找来觉得是没怎么开窗透气. ...
- 中文路径读取乱码,json乱码
strPath = 'E:\新建文件夹' #含有中文的路径,使用unicode函数转换. strPath = unicode(strPath , "utf8") 参考:http:/ ...
- python之类之多继承
class A(object): def test_func(self): print("from A") class B(A): pass # def test_func(sel ...
- 从文件中读取字符-多次调用read characters from file multiple calls
[抄题]: 接口:int read4(char * buf)一次从文件中读取 4 个字符.返回值是实际读取的字符数. 例如,如果文件中只剩下 3 个字符,则返回 3.通过使用read4 接口,实现从文 ...
- Spring的3.0提供了一种:SpEL注入方式(了解)
1. SpEL:Spring Expression Language是Spring的表达式语言,有一些自己的语法 2. 语法 * #{SpEL} 3. 例如如下的代码 <!-- SpEL的方式 ...
- 对于某些浏览器不支持placeholder的解决办法
$(function () { if (!placeholderSupport()) { $('[placeholder]').focus(function () { var input = $(th ...
- xtrabackup拷贝redolog前做的细节操作
原文地址:http://www.innomysql.net/article/25590.html 前言 淘宝3月的数据库内核月报对 xtrabackup的备份原理 做了深入的分析,写的还是很不错.不过 ...