日期间隔,当前是星期几

获取未来某一日期是星期几

/**

*  获取未来某个日期是星期几

*  注意:featureDate 传递过来的格式 必须 和 formatter.dateFormat 一致,否则endDate可能为nil

*

*/

- (NSString *)featureWeekdayWithDate:(NSString *)featureDate{

// 创建 格式 对象

NSDateFormatter *formatter = [[NSDateFormatter alloc] init];

// 设置 日期 格式 可以根据自己的需求 随时调整, 否则计算的结果可能为 nil

formatter.dateFormat = @"yyyy-MM-dd";

// 将字符串日期 转换为 NSDate 类型

NSDate *endDate = [formatter dateFromString:featureDate];

// 判断当前日期 和 未来某个时刻日期 相差的天数

long days = [self daysFromDate:[NSDate date] toDate:endDate];

// 将总天数 换算为 以 周 计算(假如 相差10天,其实就是等于 相差 1周零3天,只需要取3天,更加方便计算)

long day = days >= 7 ? days % 7 : days;

long week = [self getNowWeekday] + day;

switch (week) {

case 1:

return @"星期天";

break;

case 2:

return @"星期一";

break;

case 3:

return @"星期二";

break;

case 4:

return @"星期三";

break;

case 5:

return @"星期四";

break;

case 6:

return @"星期五";

break;

case 7:

return @"星期六";

break;

default:

break;

}

return nil;

}

/**

*  计算2个日期相差天数

*  startDate   起始日期

*  endDate     截至日期

*/

-(NSInteger)daysFromDate:(NSDate *)startDate toDate:(NSDate *)endDate {

NSDateFormatter *dateFormatter=[[NSDateFormatter alloc] init];

// 话说在真机上需要设置区域,才能正确获取本地日期,天朝代码:zh_CN

dateFormatter.locale = [[NSLocale alloc] initWithLocaleIdentifier:@"zh_CN"];

[dateFormatter setDateFormat:@"yyyy-MM-dd HH:mm:ss"];

//得到相差秒数

NSTimeInterval time = [endDate timeIntervalSinceDate:startDate];

int days = ((int)time)/(3600*24);

int hours = ((int)time)%(3600*24)/3600;

int minute = ((int)time)%(3600*24)/3600/60;

if (days <= 0 && hours <= 0&&minute<= 0) {

NSLog(@"0天0小时0分钟");

return 0;

}

else {

NSLog(@"%@",[[NSString alloc] initWithFormat:@"%i天%i小时%i分钟",days,hours,minute]);

// 之所以要 + 1,是因为 此处的days 计算的结果 不包含当天 和 最后一天\

(如星期一 和 星期四,计算机 算的结果就是2天(星期二和星期三),日常算,星期一——星期四相差3天,所以需要+1)\

对于时分 没有进行计算 可以忽略不计

return days + 1;

}

}

// 获取当前是星期几

- (NSInteger)getNowWeekday {

NSCalendar *calendar = [[NSCalendar alloc] initWithCalendarIdentifier:NSGregorianCalendar];

NSDateComponents *comps = [[NSDateComponents alloc] init];

NSInteger unitFlags = NSYearCalendarUnit | NSMonthCalendarUnit | NSDayCalendarUnit | NSWeekdayCalendarUnit |

NSHourCalendarUnit | NSMinuteCalendarUnit | NSSecondCalendarUnit;

NSDate *now = [NSDate date];

// 话说在真机上需要设置区域,才能正确获取本地日期,天朝代码:zh_CN

calendar.locale = [[NSLocale alloc] initWithLocaleIdentifier:@"zh_CN"];

comps = [calendar components:unitFlags fromDate:now];

return [comps weekday];

}

时间: 2024-10-18 18:37:05

日期间隔,当前是星期几的相关文章

java计算两日期间隔小时或分钟

public static void main(String[] args) {        try {            long min = dateDiff("2014-05-27 13:30:00","2014-05-27 13:00:00","yyyy-MM-dd HH:mm:ss");            System.out.println("---------相隔分钟数: "+min);        

ORACLE判断两个日期间隔几个工作日

CreateTime--2017年9月7日17:14:56 Author:Marydon 方法:使用存储过程 /** * 判断两个日期间隔几个工作日 */ CREATE OR REPLACE FUNCTION "FUN_BETWEENDAYS"(start_dt date, end_dt date) RETURN INT IS t_days INT; BEGIN SELECT (TRUNC(end_dt - start_dt) - ((CASE WHEN (8 - to_number(

C语言计算日期间隔天数的经典算法解析

在网上看到了一个计算日期间隔的方法,咋一看很高深,仔细看更高神,很巧妙. 先直接代码吧 #include <stdio.h> #include <stdlib.h> int day_diff(int year_start, int month_start, int day_start , int year_end, int month_end, int day_end) { int y2, m2, d2; int y1, m1, d1; m1 = (month_start + 9)

SWIFT中计算两个日期间隔多少小时

SWIFT中如何计算两个日期间隔多少个小时,其实几句代码就可以搞定了,Very Easy,在Playground内输入以下代码 var date1 = "2015-06-26 8:15:10" var dateformatter = NSDateFormatter() dateformatter.dateFormat = "yyyy-MM-dd hh:mm:ss" var dateresult = dateformatter.dateFromString(date1

格式化日期(月和星期)

// /**// * 格式化日期(月和星期)// * sFormat:日期的格式(如yy-MM-dd).年:y,月:M,日:d,时:h,分:m,秒:s// * sLanguage: 默认为中文.当为'en'的时候是英文.// */// window.dateFormat=function(date, sFormat, sLanguage){// var time = {};// time.Year = date.getFullYear();// time.TYear = ("" + t

PHP 计算两个日期间隔天数

PHP 计算两个日期间隔天数,可以使用date_diff( )函数: <?php $datetime1 = date_create('2009-10-11'); $datetime2 = date_create('2009-10-13'); $interval = date_diff($datetime1, $datetime2); echo $interval->format('%R%a days'); ?> 浏览器输出结果:

MySQL中判断日期间隔的方法

MySQL中查询一定时间间隔内的数据的方法比较常用,可以使用TO_DAYS.DATE_SUB等函数来实现. TO_DAYS函数的作用是返回指定日期从0年开始计算的天数. DATE_SUB函数的作用是通过指定日期减去指定间隔时间. 从而可以实现今天.昨天.最近7天(一周).最近30天(1个月).上个月等等查询方法.例子如下: 1.今天 SELECT * FROM t1 WHERE TO_DAYS(adddate) = TO_DAYS(CURDATE()); 2.昨天 SELECT * FROM t

C#实现的根据日期得到今天是星期几

算法如下:   基姆拉尔森计算公式: W= (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400) mod 7  在公式中d表示日期中的日数,m表示月份数,y表示年数.注意:在公式中有个与其他公式不同的地方:  把一月和二月看成是上一年的十三月和十四月,例:如果是2004-1-10则换算成:2003-13-10来代入公式计算.但是在测试的时候发现有点出入,就是公式存在一点问题,得稍做修改: W= (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400) mod 7 

js日期计算及快速获取周、月、季度起止日,获取指定日期周数以及星期几的小例子

JS获取日期时遇到如下需求,根据某年某周获取一周的日期.如开始日期规定为星期四到下一周的星期五为一周. 格式化日期: function getNowFormatDate(theDate) { var day = theDate; var Year = 0; var Month = 0; var Day = 0; var CurrentDate = ""; // 初始化时间 Year= day.getFullYear();// ie火狐下都可以 Month= day.getMonth()