当前位置: 首页 > 编程笔记 >

Java日期时间以及日期相互转换

秦毅
2023-03-14
本文向大家介绍Java日期时间以及日期相互转换,包括了Java日期时间以及日期相互转换的使用技巧和注意事项,需要的朋友参考一下

Java日期时间,以及相互转化,供大家参考,具体内容如下

package com.study.string;

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.GregorianCalendar;

public class DateBase {

 public static void main(String[] args) throws ParseException {
  /*
   * 获得当前时间
   */
  Date date1 = new Date();
  long long1 = date1.getTime();//date类型,转为 long类型
  System.out.println(date1);//Sat Aug 26 08:36:36 GMT+08:00 2017
  System.out.println(long1);//1503708031359
  
  Calendar cale1 = Calendar.getInstance();
  date1 = cale1.getTime();//calendar 类型 转为 date类型
  long1 = date1.getTime();
  System.out.println(cale1);
  System.out.println(date1);//Sat Aug 26 08:36:36 GMT+08:00 2017
  System.out.println(long1);
  
  /*
   *设置时间 
   */
  long1 += 24*60*60*1000;
  date1.setTime(long1);
  System.out.println(date1);//Sun Aug 27 08:43:26 GMT+08:00 2017
  
  /*
   * 格式化时间日期,无参数的默认格式,有参数的自定义格式。
   * Date -> String 用 format()
   * String -> Date 用 parse()
   */
  SimpleDateFormat sim1 = new SimpleDateFormat();//默认格式:17-8-27 上午8:45
  String time1 = sim1.format(date1);
  System.out.println(time1);//17-8-27 上午8:45 
  Date date11 = sim1.parse(time1);
  System.out.println(date11);
  
  SimpleDateFormat sim2 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss sss");
  String time2 = sim2.format(date1);
  System.out.println(time2);//2017-08-27 08:47:58 058
  Date date22= sim2.parse(time2);
  System.out.println(date22);//Sun Aug 27 08:52:08 GMT+08:00 2017
  
  /*
   * 创建指定日期 String 
   * GregorianCalendar
   */
  SimpleDateFormat sim3 = new SimpleDateFormat("yyyy-MM-dd");
  String str1 = "2014-09-27";
  Date date33 = sim3.parse(str1);
  System.out.println(date33);//Sat Sep 27 00:00:00 GMT+08:00 2014
  
  
  GregorianCalendar gre1 = new GregorianCalendar(2015,Calendar.DECEMBER,25);
  Date date44 = gre1.getTime();
  System.out.println(date44);//Fri Dec 25 00:00:00 GMT+08:00 2015
  
  
  Calendar cal2 = Calendar.getInstance();
  cal2.set(Calendar.YEAR, 2017);
  cal2.set(Calendar.MONTH, 7);//月份的数字与 第几个月差1, 8 == Calendar.SEPTEMBER
  cal2.set(Calendar.DATE, 26);// Tue Sep 09 09:04:25 GMT+08:00 2008
//  cal2.set(Calendar.DAY_OF_MONTH, 12);
  System.out.println(cal2.getTime());//Sat Aug 26 09:09:44 GMT+08:00 2017
  
  
  
  /*
   * 获取年月日,星期,时间
   */
  int dayOfweek = cal2.get(Calendar.DAY_OF_WEEK);
  System.out.println(dayOfweek);//7 是星期六
  
  
  /*
   * Calendar 的时间加减
   */
  Calendar cal3 = Calendar.getInstance();
  cal3.add(Calendar.YEAR, 1);
  cal3.add(Calendar.MONTH, -2);
  System.out.println(cal3.getTime());//Tue Jun 26 09:14:11 GMT+08:00 2018
  
  
  /*
   * 
   */
  Calendar cal4 = Calendar.getInstance();
  cal4.set(Calendar.YEAR, 2016);
  cal4.set(Calendar.DATE, 1);
  //每个月的最后 一天
  for(int month = Calendar.JANUARY;month<Calendar.DECEMBER; month++){
    cal4.set(Calendar.MONTH, month);
    System.out.println(cal4.get(Calendar.YEAR)+"年"+(month+1)+"月"+
      cal4.getActualMaximum(Calendar.DATE)+"日");
  }

/*
2016年1月31日
2016年2月29日
2016年3月31日
2016年4月30日
2016年5月31日
2016年6月30日
2016年7月31日
2016年8月31日
2016年9月30日
2016年10月31日
2016年11月30日
   */
  
  //直接创建long 型的时间
  long long2 = System.currentTimeMillis();
  Date daten = new Date(long2);
  System.out.println(daten);//Sat Aug 26 09:41:08 GMT+08:00 2017
 }

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。

 类似资料:
  • 本文向大家介绍Java日期时间及日期相互转换实现代码,包括了Java日期时间及日期相互转换实现代码的使用技巧和注意事项,需要的朋友参考一下 这篇文章主要介绍了Java日期时间及日期相互转换实现代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 java.util 包提供了 Date 类来封装当前的日期和时间。 Date 类提供两个构造函数来实例化

  • 本文向大家介绍java时间戳与日期相互转换工具详解,包括了java时间戳与日期相互转换工具详解的使用技巧和注意事项,需要的朋友参考一下 本文为大家分享了java日期与时间戳相互转换大全,供大家参考,具体内容如下 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。

  • 问题内容: 我接收到来自Twitter的特定日期以特定格式发送的Twitter消息: 我想将这些日期存储在带有djangos DateTimeField字段的postgresql中的“带有时区的时间戳”字段中。但是,当我存储该字符串时,出现此错误: 我可以自动将twitter datetype转换为python datetime时间(在我的应用程序中的其他地方可以保存日期)。 问题答案: 编写这样

  • 问题内容: 有谁知道如何将JS dateTime转换为MySQL datetime?还有一种方法可以向JS日期时间添加特定的分钟数,然后将其传递给MySQL日期时间? 问题答案: 尽管JS确实拥有足够的基本工具来执行此操作,但它相当笨拙。

  • 问题内容: 在这里约会我的问题: 我知道该字符串位于UTC时区。我需要将此字符串转换为“ yyy-mm-dd’T’HH:mm:ssZ”格式。 为此,我使用以下代码: 问题是此代码在时区UTC + 1的服务器上运行,其结果是: 它从初始时间删除2小时,并放置UTC时间戳(0000)。 你能帮我解决这个问题吗?谢谢。 问题答案: 如果输出格式为UTC + 1,则应在外包格式器中使用该格式,而不是UTC

  • 主要内容:日期时间和间隔数据类型的字段值,日期时间数据类型和函数,区间数据类型和函数在本章中,我们将讨论PL/SQL中的日期和时间。 PL/SQL中有两种与日期和时间相关的数据类型 - 日期时间数据类型 间隔数据类型 日期时间(Datetime)数据类型是 - 间隔数据类型是 - 日期时间和间隔数据类型的字段值 日期时间和时间间隔数据类型都由字段组成。这些字段的值决定了数据类型的值。下表列出了日期时间和间隔的字段及其可能的值。 字段名称 有效的日期时间值 有效的区间值 至(不包括