package com.opslab.util;

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

/**
* @author:Neptune
* @Description:DateUtil 提供一些常用的时间想法的方法
*/
public final class DateUtil {

//日期时间类型格式
private static final String DATETIME_FORMAT = OpslabConfig.DATETIME_FORMAT;

//日期类型格式
private static final String DATE_FORMAT = OpslabConfig.DATE_FORMAT;

//时间类型的格式
private static final String TIME_FORMAT = OpslabConfig.TIME_FORMAT;

//注意SimpleDateFormat不是线程安全的
private static ThreadLocal<SimpleDateFormat> ThreadDateTime = new ThreadLocal<SimpleDateFormat>();
private static ThreadLocal<SimpleDateFormat> ThreadDate = new ThreadLocal<SimpleDateFormat>();
private static ThreadLocal<SimpleDateFormat> ThreadTime = new ThreadLocal<SimpleDateFormat>();

private static SimpleDateFormat DateTimeInstance() {
SimpleDateFormat df = ThreadDateTime.get();
if (df == null) {
df = new SimpleDateFormat(DATETIME_FORMAT);
ThreadDateTime.set(df);
}
return df;
}

private static SimpleDateFormat DateInstance() {
SimpleDateFormat df = ThreadDate.get();
if (df == null) {
df = new SimpleDateFormat(DATE_FORMAT);
ThreadDate.set(df);
}
return df;
}

private static SimpleDateFormat TimeInstance() {
SimpleDateFormat df = ThreadTime.get();
if (df == null) {
df = new SimpleDateFormat(TIME_FORMAT);
ThreadTime.set(df);
}
return df;
}

/**
* 获取当前日期时间
*
* @return 返回当前时间的字符串值
*/
public static String currentDateTime() {
return DateTimeInstance().format(new Date());
}

/**
* 将指定的时间格式化成出返回
*
* @param date
* @return
*/
public static String dateTime(Date date) {
return DateTimeInstance().format(date);
}

/**
* 将指定的字符串解析为时间类型
*
* @param datestr
* @return
* @throws ParseException
*/
public static Date dateTime(String datestr) throws ParseException {
return DateTimeInstance().parse(datestr);
}

/**
* 获取当前的日期
*
* @return
*/
public static String currentDate() {
return DateInstance().format(new Date());
}

/**
* 将指定的时间格式化成出返回
*
* @param date
* @return
*/
public static String date(Date date) {
return DateInstance().format(date);
}

/**
* 将指定的字符串解析为时间类型
*
* @param dateStr
* @return
* @throws ParseException
*/
public static Date date(String dateStr) throws ParseException {
return DateInstance().parse(dateStr);
}

/**
* 获取当前的时间
*
* @return
*/
public static String currentTime() {
return TimeInstance().format(new Date());
}

/**
* 讲指定的时间格式化成出返回
*
* @param date
* @return
*/
public static String time(Date date) {
return TimeInstance().format(date);
}

/**
* 将指定的字符串解析为时间类型
*
* @param dateStr
* @return
* @throws ParseException
*/
public static Date time(String dateStr) throws ParseException {
return TimeInstance().parse(dateStr);
}

/**
* 在当前时间的基础上加或减去year年
*
* @param year
* @return
*/
public static Date year(int year) {
java.util.Calendar Cal = java.util.Calendar.getInstance();
Cal.setTime(new Date());
Cal.add(Calendar.YEAR, year);
return Cal.getTime();
}

/**
* 在指定的时间上加或减去几年
*
* @param date
* @param year
* @return
*/
public static Date year(Date date, int year) {
java.util.Calendar Cal = java.util.Calendar.getInstance();
Cal.setTime(date);
Cal.add(java.util.Calendar.YEAR, year);
return Cal.getTime();
}

/**
* 在当前时间的基础上加或减去几月
*
* @param month
* @return
*/
public static Date month(int month) {
java.util.Calendar Cal = java.util.Calendar.getInstance();
Cal.setTime(new Date());
Cal.add(Calendar.MONTH, month);
return Cal.getTime();
}

/**
* 在指定的时间上加或减去几月
*
* @param date
* @param month
* @return
*/
public static Date month(Date date, int month) {
java.util.Calendar Cal = java.util.Calendar.getInstance();
Cal.setTime(date);
Cal.add(java.util.Calendar.MONTH, month);
return Cal.getTime();
}

/**
* 在当前时间的基础上加或减去几天
*
* @param day
* @return
*/
public static Date day(int day) {
java.util.Calendar Cal = java.util.Calendar.getInstance();
Cal.setTime(new Date());
Cal.add(Calendar.DAY_OF_YEAR, day);
return Cal.getTime();
}

/**
* 在指定的时间上加或减去几天
*
* @param date
* @param day
* @return
*/
public static Date day(Date date, int day) {
java.util.Calendar Cal = java.util.Calendar.getInstance();
Cal.setTime(date);
Cal.add(java.util.Calendar.DAY_OF_YEAR, day);
return Cal.getTime();
}

/**
* 在当前时间的基础上加或减去几小时-支持浮点数
*
* @param hour
* @return
*/
public static Date hour(float hour) {
java.util.Calendar Cal = java.util.Calendar.getInstance();
Cal.setTime(new Date());
Cal.add(java.util.Calendar.MINUTE, (int) (hour * 60));
return Cal.getTime();
}

/**
* 在制定的时间上加或减去几小时-支持浮点数
*
* @param date
* @param hour
* @return
*/
public static Date hour(Date date, float hour) {
java.util.Calendar Cal = java.util.Calendar.getInstance();
Cal.setTime(date);
Cal.add(java.util.Calendar.MINUTE, (int) (hour * 60));
return Cal.getTime();
}

/**
* 在当前时间的基础上加或减去几分钟
*
* @param minute
* @return
*/
public static Date minute(int minute) {
java.util.Calendar Cal = java.util.Calendar.getInstance();
Cal.setTime(new Date());
Cal.add(java.util.Calendar.MINUTE, minute);
return Cal.getTime();
}

/**
* 在制定的时间上加或减去几分钟
*
* @param date
* @param minute
* @return
*/
public static Date minute(Date date, int minute) {
java.util.Calendar Cal = java.util.Calendar.getInstance();
Cal.setTime(date);
Cal.add(java.util.Calendar.MINUTE, minute);
return Cal.getTime();
}

/**
* 判断字符串是否为日期字符串
*
* @param date 日期字符串
* @return true or false
*/
public static boolean isDate(String date) {
try {
DateTimeInstance().parse(date);
return true;
} catch (ParseException e) {
e.printStackTrace();
}
return false;
}

/**
* 时间date1和date2的时间差-单位秒
*
* @param date1
* @param date2
* @return 秒
*/
public static long subtract(Date date1, Date date2) {
long cha = (date2.getTime() - date1.getTime()) / 1000;
return cha;
}

/**
* 时间date1和date2的时间差-单位秒
*
* @param date1
* @param date2
* @return 秒
*/
public static long subtract(String date1, String date2) {
long rs = 0;
try {
Date start = DateTimeInstance().parse(date1);
Date end = DateTimeInstance().parse(date2);
long cha = (end.getTime() - start.getTime()) / 1000;
rs = cha;
} catch (ParseException e) {
e.printStackTrace();
}
return rs;
}

/**
* 时间date1和date2的时间差 -单位分钟
*
* @param date1
* @param date2
* @return 分钟
*/
public static int subtractMinute(String date1, String date2) {
int rs = 0;
try {
Date start = DateTimeInstance().parse(date1);
Date end = DateTimeInstance().parse(date2);
long cha = (end.getTime() - start.getTime()) / 1000;
rs = (int) cha / (60);
} catch (ParseException e) {
e.printStackTrace();
}
return rs;
}

/**
* 时间date1和date2的时间差-单位分钟
*
* @param date1
* @param date2
* @return 分钟
*/
public static int subtractMinute(Date date1, Date date2) {
long cha = date2.getTime() - date1.getTime();
return (int) cha / (1000 * 60);
}

/**
* 时间date1和date2的时间差-单位小时
*
* @param date1
* @param date2
* @return 小时
*/
public static int subtractHour(Date date1, Date date2) {
long cha = (date2.getTime() - date1.getTime()) / 1000;
return (int) cha / (60 * 60);
}

/**
* 时间date1和date2的时间差-单位小时
*
* @param date1
* @param date2
* @return 小时
*/
public static int subtractHour(String date1, String date2) {
int rs = 0;
try {
Date start = DateTimeInstance().parse(date1);
Date end = DateTimeInstance().parse(date2);
long cha = (end.getTime() - start.getTime()) / 1000;
rs = (int) cha / (60 * 60);
} catch (ParseException e) {
e.printStackTrace();
}
return rs;
}

/**
* 时间date1和date2的时间差-单位天
*
* @param date1
* @param date2
* @return 天
*/
public static int subtractDay(String date1, String date2) {
int rs = 0;
try {
Date start = DateTimeInstance().parse(date1);
Date end = DateTimeInstance().parse(date2);
long sss = (end.getTime() - start.getTime()) / 1000;
rs = (int) sss / (60 * 60 * 24);
} catch (ParseException e) {
e.printStackTrace();
}
return rs;
}

/**
* 时间date1和date2的时间差-单位天
*
* @param date1
* @param date2
* @return 天
*/
public static int subtractDay(Date date1, Date date2) {
long cha = date2.getTime() - date1.getTime();
return (int) cha / (1000 * 60 * 60 * 24);
}

/**
* 时间date1和date2的时间差-单位月
*
* @param date1
* @param date2
* @return 月
*/
public static int subtractMonth(String date1, String date2) {
int result;
Calendar c1 = Calendar.getInstance();
Calendar c2 = Calendar.getInstance();
try {
c1.setTime(DateInstance().parse(date1));
c2.setTime(DateInstance().parse(date2));
int year1 = c1.get(Calendar.YEAR);
int month1 = c1.get(Calendar.MONTH);
int year2 = c2.get(Calendar.YEAR);
int month2 = c2.get(Calendar.MONTH);
if (year1 == year2) {
result = month2 - month1;
} else {
result = 12 * (year2 - year1) + month2 - month1;
}
} catch (ParseException e) {
e.printStackTrace();
result = -1;
}
return result;
}

/**
* 时间date1和date2的时间差-单位月
*
* @param date1
* @param date2
* @return 月
*/
public static int subtractMonth(Date date1, Date date2) {
int result;
Calendar c1 = Calendar.getInstance();
Calendar c2 = Calendar.getInstance();
c1.setTime(date1);
c2.setTime(date2);
int year1 = c1.get(Calendar.YEAR);
int month1 = c1.get(Calendar.MONTH);
int year2 = c2.get(Calendar.YEAR);
int month2 = c2.get(Calendar.MONTH);
if (year1 == year2) {
result = month2 - month1;
} else {
result = 12 * (year2 - year1) + month2 - month1;
}
return result;
}

/**
* 时间date1和date2的时间差-单位年
*
* @param date1
* @param date2
* @return 年
*/
public static int subtractYear(String date1, String date2) {
int result;
Calendar c1 = Calendar.getInstance();
Calendar c2 = Calendar.getInstance();
try {
c1.setTime(DateInstance().parse(date1));
c2.setTime(DateInstance().parse(date2));
int year1 = c1.get(Calendar.YEAR);
int year2 = c2.get(Calendar.YEAR);
result = year2 - year1;
} catch (ParseException e) {
e.printStackTrace();
result = -1;
}
return result;
}

/**
* 时间date1和date2的时间差-单位年
*
* @param date1
* @param date2
* @return 年
*/
public static int subtractYear(Date date1, Date date2) {
int result;
Calendar c1 = Calendar.getInstance();
Calendar c2 = Calendar.getInstance();
c1.setTime(date1);
c2.setTime(date2);
int year1 = c1.get(Calendar.YEAR);
int year2 = c2.get(Calendar.YEAR);
result = year2 - year1;
return result;
}

/**
* 获取俩个时间的查结果用时秒表示
*
* @param date1
* @param date2
* @return 几小时:几分钟:几秒钟
* @Summary:此处可以讲计算结果包装成一个结构体返回便于格式化
*/
public static String subtractTime(String date1, String date2) {
String result = "";
try {
Date start = DateTimeInstance().parse(date1);
Date end = DateTimeInstance().parse(date2);
long sss = (end.getTime() - start.getTime()) / 1000;
int hh = (int) sss / (60 * 60);
int mm = (int) (sss - hh * 60 * 60) / (60);
int ss = (int) (sss - hh * 60 * 60 - mm * 60);
result = hh + ":" + mm + ":" + ss;
} catch (ParseException e) {
e.printStackTrace();
}
return result;
}

/**
* 获取俩个时间的查结果用时秒表示
*
* @param date1
* @param date2
* @return 几天-几小时:几分钟:几秒钟
* @Summary:此处可以讲计算结果包装成一个结构体返回便于格式化
*/
public static String subtractDate(String date1, String date2) {
String result = "";
try {
Date start = DateTimeInstance().parse(date1);
Date end = DateTimeInstance().parse(date2);
long sss = (end.getTime() - start.getTime()) / 1000;
int dd = (int) sss / (60 * 60 * 24);
int hh = (int) (sss - dd * 60 * 60 * 24) / (60 * 60);
int mm = (int) (sss - dd * 60 * 60 * 24 - hh * 60 * 60) / (60);
int ss = (int) (sss - dd * 60 * 60 * 24 - hh * 60 * 60 - mm * 60);
result = dd + "-" + hh + ":" + mm + ":" + ss;
} catch (ParseException e) {
e.printStackTrace();
}
return result;
}

/**
* 获取俩个时间之前的相隔的天数
*
* @param startTime
* @param endTime
* @return
* @throws ParseException
*/
public static int subDay(Date startTime, Date endTime) {
int days = 0;
Calendar can1 = Calendar.getInstance();
can1.setTime(startTime);
Calendar can2 = Calendar.getInstance();
can2.setTime(endTime);
int year1 = can1.get(Calendar.YEAR);
int year2 = can2.get(Calendar.YEAR);

Calendar can = null;
if (can1.before(can2)) {
days -= can1.get(Calendar.DAY_OF_YEAR);
days += can2.get(Calendar.DAY_OF_YEAR);
can = can1;
} else {
days -= can2.get(Calendar.DAY_OF_YEAR);
days += can1.get(Calendar.DAY_OF_YEAR);
can = can2;
}
for (int i = 0; i < Math.abs(year2 - year1); i++) {
days += can.getActualMaximum(Calendar.DAY_OF_YEAR);
can.add(Calendar.YEAR, 1);
}

return days;
}

/**
* 获取俩个时间之前的相隔的天数
*
* @param startTime
* @param endTime
* @return
* @throws ParseException
*/
public static int subDay(String startTime, String endTime) {
int days = 0;
try {
Date date1 = DateInstance().parse(DateInstance().format(DateTimeInstance().parse(startTime)));
Date date2 = DateInstance().parse(DateInstance().format(DateTimeInstance().parse(endTime)));
Calendar can1 = Calendar.getInstance();
can1.setTime(date1);
Calendar can2 = Calendar.getInstance();
can2.setTime(date2);
int year1 = can1.get(Calendar.YEAR);
int year2 = can2.get(Calendar.YEAR);

Calendar can = null;
if (can1.before(can2)) {
days -= can1.get(Calendar.DAY_OF_YEAR);
days += can2.get(Calendar.DAY_OF_YEAR);
can = can1;
} else {
days -= can2.get(Calendar.DAY_OF_YEAR);
days += can1.get(Calendar.DAY_OF_YEAR);
can = can2;
}
for (int i = 0; i < Math.abs(year2 - year1); i++) {
days += can.getActualMaximum(Calendar.DAY_OF_YEAR);
can.add(Calendar.YEAR, 1);
}

} catch (ParseException e) {
e.printStackTrace();
}
return days;
}

/**
* 返回俩个时间在时间段(例如每天的08:00-18:00)的时长-单位秒
*
* @param startDate
* @param endDate
* @param timeBurst 只就按该时间段内的08:00-18:00时长
* @return 计算后的秒数
* @throws ParseException
* @summary 格式错误返回0
*/
public static long subtimeBurst(String startDate, String endDate, String timeBurst)
throws ParseException {
Date start = DateTimeInstance().parse(startDate);
Date end = DateTimeInstance().parse(endDate);
return subtimeBurst(start, end, timeBurst);
}

/**
* 返回俩个时间在时间段(例如每天的08:00-18:00)的时长-单位秒
*
* @param startDate
* @param endDate
* @param timeBurst 只就按该时间段内的08:00-18:00时长
* @return 计算后的秒数
* @throws ParseException
*/
public static long subtimeBurst(Date startDate, Date endDate, String timeBurst)
throws ParseException {
long second = 0;
Pattern p = Pattern.compile("^\\d{2}:\\d{2}-\\d{2}:\\d{2}");
Matcher m = p.matcher(timeBurst);
boolean falg = false;
if (startDate.after(endDate)) {
Date temp = startDate;
startDate = endDate;
endDate = temp;
falg = true;
}
if (m.matches()) {
String[] a = timeBurst.split("-");
int day = subDay(startDate, endDate);
if (day > 0) {
long firstMintues = 0;
long lastMintues = 0;
long daySecond = 0;
String strDayStart = DateInstance().format(startDate) + " " + a[0] + ":00";
String strDayEnd = DateInstance().format(startDate) + " " + a[1] + ":00";
Date dayStart = DateTimeInstance().parse(strDayStart);
Date dayEnd = DateTimeInstance().parse(strDayEnd);
daySecond = subtract(dayStart, dayEnd);
if ((startDate.after(dayStart) || startDate.equals(dayStart))
&& startDate.before(dayEnd)) {
firstMintues = (dayEnd.getTime() - startDate.getTime()) / 1000;
} else if (startDate.before(dayStart)) {
firstMintues = (dayEnd.getTime() - dayStart.getTime()) / 1000;
}
dayStart = DateTimeInstance().parse(DateInstance().format(endDate) + " " + a[0] + ":00");
dayEnd = DateTimeInstance().parse(DateInstance().format(endDate) + " " + a[1] + ":00");
if (endDate.after(dayStart) && (endDate.before(dayEnd) || endDate.equals(dayEnd))) {
lastMintues = (endDate.getTime() - dayStart.getTime()) / 1000;
} else if (endDate.after(dayEnd)) {
lastMintues = (dayEnd.getTime() - dayStart.getTime()) / 1000;
}
//第一天的秒数 + 最好一天的秒数 + 天数*全天的秒数
second = firstMintues + lastMintues;
second += (day - 1) * daySecond;
} else {
String strDayStart = DateInstance().format(startDate) + " " + a[0] + ":00";
String strDayEnd = DateInstance().format(startDate) + " " + a[1] + ":00";
Date dayStart = DateTimeInstance().parse(strDayStart);
Date dayEnd = DateTimeInstance().parse(strDayEnd);
if ((startDate.after(dayStart) || startDate.equals(dayStart))
&& startDate.before(dayEnd) && endDate.after(dayStart)
&& (endDate.before(dayEnd) || endDate.equals(dayEnd))) {
second = (endDate.getTime() - startDate.getTime()) / 1000;
} else {
if (startDate.before(dayStart)) {
if (endDate.before(dayEnd)) {
second = (endDate.getTime() - dayStart.getTime()) / 1000;
} else {
second = (dayEnd.getTime() - dayStart.getTime()) / 1000;
}
}
if (startDate.after(dayStart)) {
if (endDate.before(dayEnd)) {
second = (endDate.getTime() - startDate.getTime()) / 1000;
} else {
second = (dayEnd.getTime() - startDate.getTime()) / 1000;
}
}
}
if ((startDate.before(dayStart) && endDate.before(dayStart))
|| startDate.after(dayEnd) && endDate.after(dayEnd)) {
second = 0;
}
}
} else {
second = (endDate.getTime() - startDate.getTime()) / 1000;
}
if (falg) {
second = Long.parseLong("-" + second);
}
return second;
}

/**
* 时间Date在时间段(例如每天的08:00-18:00)上增加或减去second秒
*
* @param date
* @param second
* @param timeBurst
* @return 计算后的时间
* @Suumary 指定的格式错误后返回原数据
*/
public static Date calculate(String date, int second, String timeBurst) {
Date start = null;
try {
start = DateTimeInstance().parse(date);
return calculate(start, second, timeBurst);
} catch (ParseException e) {
e.printStackTrace();
}
return new Date();
}

/**
* 时间Date在时间段(例如每天的08:00-18:00)上增加或减去second秒
*
* @param date
* @param second
* @param timeBurst
* @return 计算后的时间
* @Suumary 指定的格式错误后返回原数据
*/
public static Date calculate(Date date, int second, String timeBurst) {
Pattern p = Pattern.compile("^\\d{2}:\\d{2}-\\d{2}:\\d{2}");
Matcher m = p.matcher(timeBurst);
java.util.Calendar cal = java.util.Calendar.getInstance();
if (m.matches()) {
String[] a = timeBurst.split("-");
try {
Date dayStart = DateTimeInstance().parse(DateInstance().format(date) + " " + a[0] + ":00");
Date dayEnd = DateTimeInstance().parse(DateInstance().format(date) + " " + a[1] + ":00");
int DaySecond = (int) subtract(dayStart, dayEnd);
int toDaySecond = (int) subtract(dayStart, dayEnd);
if (second >= 0) {
if ((date.after(dayStart) || date.equals(dayStart))
&& (date.before(dayEnd) || date.equals(dayEnd))) {
cal.setTime(date);
toDaySecond = (int) subtract(date, dayEnd);
}
if (date.before(dayStart)) {
cal.setTime(dayStart);
toDaySecond = (int) subtract(dayStart, dayEnd);
}
if (date.after(dayEnd)) {
cal.setTime(day(dayStart, 1));
toDaySecond = 0;
}

if (second > toDaySecond) {
int day = (second - toDaySecond) / DaySecond;
int remainder = (second - toDaySecond) % DaySecond;
cal.setTime(day(dayStart, 1));
cal.add(Calendar.DAY_OF_YEAR, day);
cal.add(Calendar.SECOND, remainder);
} else {
cal.add(Calendar.SECOND, second);
}

} else {
if ((date.after(dayStart) || date.equals(dayStart))
&& (date.before(dayEnd) || date.equals(dayEnd))) {
cal.setTime(date);
toDaySecond = (int) subtract(date, dayStart);
}
if (date.before(dayStart)) {
cal.setTime(day(dayEnd, -1));
toDaySecond = 0;
}
if (date.after(dayEnd)) {
cal.setTime(dayEnd);
toDaySecond = (int) subtract(dayStart, dayEnd);
}
if (Math.abs(second) > Math.abs(toDaySecond)) {
int day = (Math.abs(second) - Math.abs(toDaySecond)) / DaySecond;
int remainder = (Math.abs(second) - Math.abs(toDaySecond)) % DaySecond;
cal.setTime(day(dayEnd, -1));
cal.add(Calendar.DAY_OF_YEAR, Integer.valueOf("-" + day));
cal.add(Calendar.SECOND, Integer.valueOf("-" + remainder));
} else {
cal.add(Calendar.SECOND, second);
}
}
} catch (ParseException e) {
e.printStackTrace();
}
} else {
cal.setTime(date);
}
return cal.getTime();
}

/**
* 判断是否在某个时间段内
* @param startTime
* @param endTime
* @param date
* @return
* @throws ParseException
*/
public static boolean between(String startTime,String endTime,Date date)
throws ParseException {
return between(dateTime(startTime),dateTime(endTime),date);
}

/**
* 判断在某个时间内
* @param startTime
* @param endTime
* @param date
* @return
*/
public static boolean between(Date startTime,Date endTime,Date date){
return date.after(startTime) && date.before(endTime);
}
}

DateUtil 提供一些常用的时间想法的方法的更多相关文章

  1. 常用sql时间字符转化

    这边主要用到2个函数  convert()  cast() cast是对数据字符类型的转化,例如: cast(date as datetime)   这样就将date字段转化成为时间类型了 因为常用到 ...

  2. SQL中常用的时间格式

    一些常用的时间格式 先讲一下一些基本的格式模式 格式模式      说明 d                   月中的某一天.一位数的日期没有前导零. dd                 月中的某 ...

  3. Net Framework中的提供的常用委托类型

    .Net Framework中的提供的常用委托类型   .Net Framework中提供有一些常用的预定义委托:Action.Func.Predicate.用到委托的时候建议尽量使用这些委托类型,而 ...

  4. linux常用的时间获取函数(time,gettimeofday,clock_gettime,_ftime,localtime,strftime )

    time()提供了秒级的精确度 1.头文件 <time.h> 2.函数原型 time_t time(time_t * timer) 函数返回从TC1970-1-1 0:0:0开始到现在的秒 ...

  5. IDLE提供的常用快捷键

    IDLE提供的常用快捷键 快捷键 说明 适用于 F1 打开Python帮助文档 Python文件窗口和shell窗口均可用 Alt+P 浏览历史命令(上一条) 仅Python Shell窗口可用 Al ...

  6. Python常用模块-时间模块(time&datetime)

    Python常用模块-时间模块(time & datetime) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.初始time模块 #!/usr/bin/env pyth ...

  7. js中常用日期时间转换

    常用日期时间处理插件:1. timeago.js处理几分钟之前    2. day.js    3. moment.js 注意: 1. 此处的标准时间格式为  2018-03-23 13:35:47 ...

  8. 常用SQL时间格式SQLServer中文版的默认的日期字段datetime格式是yyyy-mm-d

    常用SQL时间格式 SQL Server中文版的默认的日期字段datetime格式是yyyy-mm-dd Thh:mm:ss.mmm 例如: select getdate() -- ::08.177 ...

  9. 问题:Oracle to_date;结果:oracle常用的时间格式转换

    oracle常用的时间格式转换 1:取得当前日期是本月的第几周 SQL> select to_char(sysdate,'YYYYMMDD W HH24:MI:SS') from dual; T ...

随机推荐

  1. wordpress实现主动推送+熊掌号推送同步进行

    今天给一个朋友http://www.myunigift.cn/ 这个站点是用wordpress,今天帮他改造熊掌号,于是做了数据同步推送. 只要把下面的代码写到funtions.php里面,发布文章的 ...

  2. git常用命令总结--原创

    0.git status 仓库状态1.git add 工作区-->暂存区2.git commit 暂存区-->版本库3.git log 查看日志4.git reset --hard hea ...

  3. String 堆内存和栈内存

    java把内存划分为两种:一种是栈(stack)内存,一种是堆(heap)内存 在函数中定义的一些基本类型的变量和对象的引用变量都在栈内存中分配,当在一段代码块定义一个变量时,java就在栈中为这个变 ...

  4. nginx优化、负载均衡、rewrite

    nginx优化 # 普通用户启动 (useradd nginx -s /sbin/nologin -M) user nginx; # 配置nginx worker进程个数 #worker_proces ...

  5. Kylin 架构模块简介

    Apache Kylin™是一个开源的分布式分析引擎,提供Hadoop/Spark之上的SQL查询接口及多维分析(OLAP)能力以支持超大规模数据,最初由eBay Inc. 开发并贡献至开源社区.它能 ...

  6. RookeyFrame 添加 导入功能

    我遇到的情况: 我在‘模块管理’里面, 把模块‘客户联系人’的‘允许导入’勾上,保存后,在‘客户联系人’页面没有导入按钮, 模块‘客户主数据’却可以, 这是为什么额?两个模块都是线下创建的,是哪儿不一 ...

  7. 99: AGC-018C 堆+思维

    $des$有 $X + Y + Z$ 个人,第 $i$ 个人有 $A_i$ 个金币,$B_i$ 个银币,$C_i$ 个铜币.选出 $X$ 个人获得其金币,选出 $Y$ 个人获得其银币,选出 $Z$ 个 ...

  8. linux 下终端通过证书、私钥快捷登录

    ssh -i 你的证书 root@IP地址 -p 端口号 ssh -i {您的 .pem 文件的完整路径} ec2-user@{实例 IP 地址} 设置秘钥权限chmod 600 ~/.ssh/id_ ...

  9. linux系统下常用的打包/解压缩包命令

    此处大概列了常用的解压和打包命令,详细信息需要百度一一对比他们的区别,比如我们在下载软件时就是最好的实践. 用zip举例说明,使用命令压缩时有点是,压缩文件.目录会非常快:如图,我压缩了一个progr ...

  10. 第02组 Alpha冲刺(2/6)

    队名:無駄無駄 组长博客 作业博客 组员情况 张越洋 过去两天完成了哪些任务 任务分配.进度监督 提交记录(全组共用) 接下来的计划 沟通前后端成员,监督.提醒他们尽快完成各自的进度 还剩下哪些任务 ...