日期类的加减及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) ...
随机推荐
- 关于时间查询的sql语句
今天 select * from 表名 where to_days(时间字段名) = to_days(now()); 昨天 SELECT * FROM 表名 WHERE TO_DAYS( NOW( ) ...
- EasyUI查询
<script type="text/javascript"> <!-- js --> function search_xxx() { var search ...
- Food(最大流)
Food http://acm.hdu.edu.cn/showproblem.php?pid=4292 Time Limit: 2000/1000 MS (Java/Others) Memory ...
- Finding Hotels
Finding Hotels http://acm.hdu.edu.cn/showproblem.php?pid=5992 Time Limit: 2000/1000 MS (Java/Others) ...
- MYSQL错误:You can't specify target table for update in FROM clause
这句话意思是:不能先select再更新(修改)同一个表. 可以再外嵌套多一层,这个问题只有mysql有,mssql和oracle都没有. # 出错delete from Person where Id ...
- 127单词接龙 1· Word Ladder1
找出最短路径 [抄题]: Given two words (beginWord and endWord), and a dictionary's word list, find the length ...
- dede中arcurl的解析
有时候我们需要在dede中通过$dsql查询出文章数据,并生成文章的地址. 但是dede默认的dede_archives和附加表dede_addonarticle都没有存放arcurl的字段. 说明a ...
- 源码安装php时出现Sorry, I cannot run apxs. Possible reasons follow:
1.可能的原因是你没有安装perl > yum install perl > yum install httpd-devel 2.在你apache安装目录下的bin下找到apxs,并用vi ...
- dddddddddddddddddd
PacificA: Replication in log-based distributed storage systemshttp://research.microsoft.com:8082/pub ...
- Banner设计的视觉导向原则分析
Banner的布局方式 常见的Banner布局方式有五种,以下分别给出大致样式: 两栏式: 三栏式: 组合式: 一体式: 对角线式: 以上几种布局方式不分好坏,对于不同的主题.素材和文案可以自行选 ...