java日期操作常用方法

Wesley13
• 阅读 702
/**   
     * 取得指定月份的第一天   
     *   
     * @param strdate String   
     * @return String   
     */   
    public String getMonthBegin(String strdate)    
    {    
        java.util.Date date = parseFormatDate(strdate);    
        return formatDateByFormat(date,"yyyy-MM") + "-01";    
    }    
   
    /**   
     * 取得指定月份的最后一天   
     *   
     * @param strdate String   
     * @return String   
     */   
    public String getMonthEnd(String strdate)    
    {    
        java.util.Date date = parseFormatDate(getMonthBegin(strdate));    
        Calendar calendar = Calendar.getInstance();    
        calendar.setTime(date);    
        calendar.add(Calendar.MONTH,1);    
        calendar.add(Calendar.DAY_OF_YEAR, -1);    
        return formatDate(calendar.getTime());    
    }    
   
    /**   
     * 常用的格式化日期   
     *   
     * @param date Date   
     * @return String   
     */   
    public String formatDate(java.util.Date date)    
    {    
        return formatDateByFormat(date,"yyyy-MM-dd");    
    }    
   
    /**   
     * 以指定的格式来格式化日期   
     *   
     * @param date Date   
     * @param format String   
     * @return String   
     */   
    public String formatDateByFormat(java.util.Date date,String format)    
    {    
        String result = "";    
        if(date != null)    
        {    
            try   
            {    
                SimpleDateFormat sdf = new SimpleDateFormat(format);    
                result = sdf.format(date);    
            }    
            catch(Exception ex)    
            {    
                LOGGER.info("date:" + date);    
                ex.printStackTrace();    
            }    
        }    
        return result;    
    }    
   
   
   
/**   
 * 日期操作   
 *    
 * @author xxx   
 * @version 2.0 jdk1.4.0 tomcat5.1.0 * Updated Date:2005/03/10   
 */   
public class DateUtil {    
 /**   
  * 格式化日期   
  *    
  * @param dateStr   
  *            字符型日期   
  * @param format   
  *            格式   
  * @return 返回日期   
  */   
 public static java.util.Date parseDate(String dateStr, String format) {    
  java.util.Date date = null;    
  try {    
   java.text.DateFormat df = new java.text.SimpleDateFormat(format);    
   String dt=Normal.parse(dateStr).replaceAll(    
     "-", "/");    
   if((!dt.equals(""))&&(dt.length()<format.length())){    
    dt+=format.substring(dt.length()).replaceAll("[YyMmDdHhSs]","0");    
   }    
   date = (java.util.Date) df.parse(dt);    
  } catch (Exception e) {    
  }    
  return date;    
 }    
   
 public static java.util.Date parseDate(String dateStr) {    
  return parseDate(dateStr, "yyyy/MM/dd");    
 }    
   
 public static java.util.Date parseDate(java.sql.Date date) {    
  return date;    
 }    
     
 public static java.sql.Date parseSqlDate(java.util.Date date) {    
  if (date != null)    
   return new java.sql.Date(date.getTime());    
  else   
   return null;    
 }    
   
 public static java.sql.Date parseSqlDate(String dateStr, String format) {    
  java.util.Date date = parseDate(dateStr, format);    
  return parseSqlDate(date);    
 }    
   
 public static java.sql.Date parseSqlDate(String dateStr) {    
  return parseSqlDate(dateStr, "yyyy/MM/dd");    
 }    
   
     
 public static java.sql.Timestamp parseTimestamp(String dateStr,    
   String format) {    
  java.util.Date date = parseDate(dateStr, format);    
  if (date != null) {    
   long t = date.getTime();    
   return new java.sql.Timestamp(t);    
  } else   
   return null;    
 }    
   
 public static java.sql.Timestamp parseTimestamp(String dateStr) {    
  return parseTimestamp(dateStr, "yyyy/MM/dd HH:mm:ss");    
 }    
   
 /**   
  * 格式化输出日期   
  *    
  * @param date   
  *            日期   
  * @param format   
  *            格式   
  * @return 返回字符型日期   
  */   
 public static String format(java.util.Date date, String format) {    
  String result = "";    
  try {    
   if (date != null) {    
    java.text.DateFormat df = new java.text.SimpleDateFormat(format);    
    result = df.format(date);    
   }    
  } catch (Exception e) {    
  }    
  return result;    
 }    
   
 public static String format(java.util.Date date) {    
  return format(date, "yyyy/MM/dd");    
 }    
   
 /**   
  * 返回年份   
  *    
  * @param date   
  *            日期   
  * @return 返回年份   
  */   
 public static int getYear(java.util.Date date) {    
  java.util.Calendar c = java.util.Calendar.getInstance();    
  c.setTime(date);    
  return c.get(java.util.Calendar.YEAR);    
 }    
   
 /**   
  * 返回月份   
  *    
  * @param date   
  *            日期   
  * @return 返回月份   
  */   
 public static int getMonth(java.util.Date date) {    
  java.util.Calendar c = java.util.Calendar.getInstance();    
  c.setTime(date);    
  return c.get(java.util.Calendar.MONTH) + 1;    
 }    
   
 /**   
  * 返回日份   
  *    
  * @param date   
  *            日期   
  * @return 返回日份   
  */   
 public static int getDay(java.util.Date date) {    
  java.util.Calendar c = java.util.Calendar.getInstance();    
  c.setTime(date);    
  return c.get(java.util.Calendar.DAY_OF_MONTH);    
 }    
   
 /**   
  * 返回小时   
  *    
  * @param date   
  *            日期   
  * @return 返回小时   
  */   
 public static int getHour(java.util.Date date) {    
  java.util.Calendar c = java.util.Calendar.getInstance();    
  c.setTime(date);    
  return c.get(java.util.Calendar.HOUR_OF_DAY);    
 }    
   
 /**   
  * 返回分钟   
  *    
  * @param date   
  *            日期   
  * @return 返回分钟   
  */   
 public static int getMinute(java.util.Date date) {    
  java.util.Calendar c = java.util.Calendar.getInstance();    
  c.setTime(date);    
  return c.get(java.util.Calendar.MINUTE);    
 }    
   
 /**   
  * 返回秒钟   
  *    
  * @param date   
  *            日期   
  * @return 返回秒钟   
  */   
 public static int getSecond(java.util.Date date) {    
  java.util.Calendar c = java.util.Calendar.getInstance();    
  c.setTime(date);    
  return c.get(java.util.Calendar.SECOND);    
 }    
   
 /**   
  * 返回毫秒   
  *    
  * @param date   
  *            日期   
  * @return 返回毫秒   
  */   
 public static long getMillis(java.util.Date date) {    
  java.util.Calendar c = java.util.Calendar.getInstance();    
  c.setTime(date);    
  return c.getTimeInMillis();    
 }    
   
 /**   
  * 返回字符型日期   
  *    
  * @param date   
  *            日期   
  * @return 返回字符型日期   
  */   
 public static String getDate(java.util.Date date) {    
  return format(date, "yyyy/MM/dd");    
 }    
   
 /**   
  * 返回字符型时间   
  *    
  * @param date   
  *            日期   
  * @return 返回字符型时间   
  */   
 public static String getTime(java.util.Date date) {    
  return format(date, "HH:mm:ss");    
 }    
   
 /**   
  * 返回字符型日期时间   
  *    
  * @param date   
  *            日期   
  * @return 返回字符型日期时间   
  */   
 public static String getDateTime(java.util.Date date) {    
  return format(date, "yyyy/MM/dd HH:mm:ss");    
 }    
   
 /**   
  * 日期相加   
  *    
  * @param date   
  *            日期   
  * @param day   
  *            天数   
  * @return 返回相加后的日期   
  */   
 public static java.util.Date addDate(java.util.Date date, int day) {    
  java.util.Calendar c = java.util.Calendar.getInstance();    
  c.setTimeInMillis(getMillis(date) + ((long) day) * 24 * 3600 * 1000);    
  return c.getTime();    
 }    
   
 /**   
  * 日期相减   
  *    
  * @param date   
  *            日期   
  * @param date1   
  *            日期   
  * @return 返回相减后的日期   
  */   
 public static int diffDate(java.util.Date date, java.util.Date date1) {    
  return (int) ((getMillis(date) - getMillis(date1)) / (24 * 3600 * 1000));    
 }     
}    
   
   
   
Calendar now = Calendar.getInstance();    
int year = now.get(Calendar.YEAR);    
int date = now.get(Calendar.DAY_OF_MONTH);    
int month = now.get(Calendar.MONTH) + 1;    
int hour = now.get(Calendar.HOUR);    
int min = now.get(Calendar.MINUTE);    
int sec = now.get(Calendar.SECOND);    
   
   
   
   
import java.sql.Timestamp;    
import java.text.SimpleDateFormat;    
import java.util.*;    
/**    
 *  
 *    
public class ManageWeek {    
 //判断两个日期是否在同一周    
 boolean isSameWeekDates(Date date1, Date date2) {    
  Calendar cal1 = Calendar.getInstance();    
  Calendar cal2 = Calendar.getInstance();    
  cal1.setTime(date1);    
  cal2.setTime(date2);    
  int subYear = cal1.get(Calendar.YEAR) - cal2.get(Calendar.YEAR);    
  if (0 == subYear) {    
    if (cal1.get(Calendar.WEEK_OF_YEAR) == cal2.get(Calendar.WEEK_OF_YEAR))    
   return true;    
  }    
  else if (1 == subYear && 11 == cal2.get(Calendar.MONTH)) {    
    // 如果12月的最后一周横跨来年第一周的话则最后一周即算做来年的第一周    
    if (cal1.get(Calendar.WEEK_OF_YEAR) == cal2.get(Calendar.WEEK_OF_YEAR))    
   return true;    
  }    
  else if (-1 == subYear && 11 == cal1.get(Calendar.MONTH)) {    
    if (cal1.get(Calendar.WEEK_OF_YEAR) == cal2.get(Calendar.WEEK_OF_YEAR))    
   return true;    
  }    
  return false;    
 }    
     
     
 //产生周序列    
 public static String  getSeqWeek(){    
  Calendar c = Calendar.getInstance(Locale.CHINA);    
  String week = Integer.toString(c.get(Calendar.WEEK_OF_YEAR));    
  if(week.length()==1)week = "0" + week;    
  String year = Integer.toString(c.get(Calendar.YEAR));      
  return year+week;    
      
 }    
      
  //获得周一的日期    
  public static String getMonday(Date date){    
   Calendar c = Calendar.getInstance();    
   c.setTime(date);    
   c.set(Calendar.DAY_OF_WEEK,Calendar.MONDAY);    
   return new SimpleDateFormat("yyyy-MM-dd").format(c.getTime());    
  }    
      
      
  //获得周五的日期    
  public static String getFriday(Date date){    
   Calendar c = Calendar.getInstance();    
   c.setTime(date);    
   c.set(Calendar.DAY_OF_WEEK,Calendar.FRIDAY);       
   return new SimpleDateFormat("yyyy-MM-dd").format(c.getTime());    
       
       
  }
  public static void main(String[] args){    
   
  }    
   
}

参见:http://brucezheng.javaeye.com/blog/86967

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
3年前
Java爬虫之JSoup使用教程
title:Java爬虫之JSoup使用教程date:201812248:00:000800update:201812248:00:000800author:mecover:https://imgblog.csdnimg.cn/20181224144920712(https://www.oschin
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Stella981 Stella981
3年前
HIVE 时间操作函数
日期函数UNIX时间戳转日期函数: from\_unixtime语法:   from\_unixtime(bigint unixtime\, string format\)返回值: string说明: 转化UNIX时间戳(从19700101 00:00:00 UTC到指定时间的秒数)到当前时区的时间格式举例:hive   selec
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这
美凌格栋栋酱 美凌格栋栋酱
14小时前
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(