NSDate的处理:前一天、后一天等关于时区偏移的处理以及在数据库中的使用

2024-08-22 18:38

本文主要是介绍NSDate的处理:前一天、后一天等关于时区偏移的处理以及在数据库中的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

看来很多网上关于日期的处理,今天、昨天、前天、后天、一周等,满心欢喜的拿着去验证结果总是不尽如人意,看别别人的代码看的脑涨,自己就写一个简单的,自己来用,以后用其他的方法,我会在完善,再次记录,以方便以后查阅

                                                                                                                                    --宋飞祥    2014.7.19

直接上代码,很容易理解:

#import <Foundation/Foundation.h>@interface MyCutomNSDateDeal : NSObject+(NSInteger)timeZoneOffset;
+(NSInteger)preDayOfTheDate_start:(NSDate *)date;
+(NSInteger)preDayOfTheDate_end:(NSDate *)date;
+(NSInteger)nextDayOfTheDate_start:(NSDate *)date;
+(NSInteger)nextDayOfTheDate_end:(NSDate *)date;@end

#import "MyCutomNSDateDeal.h"@implementation MyCutomNSDateDeal+(NSInteger)timeZoneOffset
{NSDate *date = [NSDate date];NSTimeZone *zone = [NSTimeZone systemTimeZone];NSInteger offset = [zone secondsFromGMTForDate:date];return offset;
}
/***  根据给出的日期,返回该日期的前一天的起点(相对于日期起点,seconds的计数)**  @param date 日期**  @return 返回的是seconds计数,相对于日历系统起始至该日期前一天的起点(就是0点)*/
+(NSInteger)preDayOfTheDate_start:(NSDate *)date
{NSCalendar *cal = [NSCalendar currentCalendar];NSDateComponents *components = [cal components:(NSHourCalendarUnit | NSMinuteCalendarUnit|NSSecondCalendarUnit) fromDate:date];[components setHour:-[components hour]-24];[components setMinute:-[components minute]];[components setSecond:-[components second]];NSDate *date1 = [cal dateByAddingComponents:components toDate:date options:0];return [date1 timeIntervalSince1970]+[self timeZoneOffset];
}/***  根据给出的日期,返回该日期的前一天的终点(也就是给出日期的起点)**  @param date 给定的日期**  @return 返回的是seconds计数*/
+(NSInteger)preDayOfTheDate_end:(NSDate *)date
{NSCalendar *cal = [NSCalendar currentCalendar];NSDateComponents *components = [cal components:(NSHourCalendarUnit | NSMinuteCalendarUnit|NSSecondCalendarUnit) fromDate:date];[components setHour:-[components hour]];[components setMinute:-[components minute]];[components setSecond:-[components second]];NSDate *date1 = [cal dateByAddingComponents:components toDate:date options:0];return [date1 timeIntervalSince1970]+[self timeZoneOffset];
}+(NSInteger)nextDayOfTheDate_start:(NSDate *)date
{NSCalendar *cal = [NSCalendar currentCalendar];NSDateComponents *components = [cal components:(NSHourCalendarUnit | NSMinuteCalendarUnit|NSSecondCalendarUnit) fromDate:date];[components setHour:-[components hour]+24];[components setMinute:-[components minute]];[components setSecond:-[components second]];NSDate *date1 = [cal dateByAddingComponents:components toDate:date options:0];return [date1 timeIntervalSince1970]+[self timeZoneOffset];}+(NSInteger)nextDayOfTheDate_end:(NSDate *)date
{NSCalendar *cal = [NSCalendar currentCalendar];NSDateComponents *components = [cal components:(NSHourCalendarUnit | NSMinuteCalendarUnit|NSSecondCalendarUnit) fromDate:date];[components setHour:-[components hour]+ 2*24];[components setMinute:-[components minute]];[components setSecond:-[components second]];NSDate *date1 = [cal dateByAddingComponents:components toDate:date options:0];return [date1 timeIntervalSince1970]+[self timeZoneOffset];}//+(NSInteger)preWeekOfTheDate_@end


使用如下:

这里我取得date 为当天的,用户可以换成自己想要的相对日期即可!!

 NSDate *today = [NSDate date];NSLog(@"today ::::: %@",today);NSInteger today_int = [MyCutomNSDateDeal preDayOfTheDate_start:today];NSDate *per_start = [NSDate dateWithTimeIntervalSince1970:today_int];NSLog(@"per_start _:_ %@",per_start);NSDate *per_end = [NSDate dateWithTimeIntervalSince1970:[MyCutomNSDateDeal preDayOfTheDate_end:today]];NSLog(@"per_end -:- %@",per_end);NSDate *next_start = [NSDate dateWithTimeIntervalSince1970:[MyCutomNSDateDeal nextDayOfTheDate_start:today]];NSDate *next_end = [NSDate dateWithTimeIntervalSince1970:[MyCutomNSDateDeal nextDayOfTheDate_end:today]];NSLog(@"next_start === %@",next_start);NSLog(@"next_end === %@",next_end);
打印结果如下:

2014-07-19 <span style="color:#FF0000;">15:26:30.565 </span>FMDBSortByDateDemo[4423:60b] today ::::: 2014-07-19 <span style="color:#FF0000;">07:26:30</span> +0000
2014-07-19 15:26:30.566 FMDBSortByDateDemo[4423:60b] per_start _:_ 2014-07-18 00:00:00 +0000
2014-07-19 15:26:30.566 FMDBSortByDateDemo[4423:60b] per_end -:- 2014-07-19 00:00:00 +0000
2014-07-19 15:26:30.566 FMDBSortByDateDemo[4423:60b] next_start === 2014-07-20 00:00:00 +0000
2014-07-19 15:26:30.567 FMDBSortByDateDemo[4423:60b] next_end === 2014-07-21 00:00:00 +0000
第一行打印可以看出,我们打印的时间理我现在真正需要的时间差8个小时,这就是时区的偏移,加上8个小时就对了,下面的打印在我定义的头文件中,已经把相对偏加上了!


这里我想说的是:我项目中用到要存数据和date,而数据库(FMDB)是不支持date格式的,我采取的是把相对日历起点的seconds(秒)存起来,通过比对秒数来取想要的数据!

如果大家有好的方法,可以交流!!

下面是我的数据库取值过程:

 NSInteger inter = [MyCutomNSDateDeal preDayOfTheDate_end:today];NSString *sql = [NSString stringWithFormat:@"SELECT * FROM Temperature WHERE Date > %i ",inter];// NSString *sql = [NSString stringWithFormat:@"SELECT * FROM Temperature WHERE Date between %li and %li",from,to];if ([db open]) {FMResultSet *rs = [db executeQuery:sql];while ([rs next]) {NSString *name = [rs stringForColumn:@"Name"];NSInteger time = [rs intForColumn:@"Date"];NSDate *date = [NSDate dateWithTimeIntervalSince1970:time];float temp = [rs doubleForColumn:@"Temperature"];NSString *event = [rs stringForColumn:@"Event"];NSLog(@"Name:%@,Date:%@,Temperature:%f,Event:%@",name,date,temp,event);}}

两个sql语句都验证了,是正确的,有一点我要说的是,我们在处理取出的数据时,加上了偏移量,所以我们存取数据时,也要加上偏移量,应该如下:

-(void)temperatureAndDateUpdate:(float)value
{NSDate *date = [NSDate date];NSInteger time = [date timeIntervalSince1970];time = time + [MyCutomNSDateDeal timeZoneOffset]; //加上时区偏移量NSDate *date1 = [NSDate dateWithTimeIntervalSince1970:time];NSLog(@"temperature update    date1 === %@",date1);if ([db open]) {[db executeUpdate:@"INSERT INTO Temperature(Name,Date,Temperature,Event) VALUES (?,?,?,?)",@"SFX",[NSNumber numberWithInteger:time],[NSNumber numberWithFloat:value],@"吃药"];NSLog(@"success!!");}else{NSLog(@"error:   %@   %@",[db lastError],[db lastErrorMessage]);}[db close];
}


这篇关于NSDate的处理:前一天、后一天等关于时区偏移的处理以及在数据库中的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1097079

相关文章

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读

Python Transformers库(NLP处理库)案例代码讲解

《PythonTransformers库(NLP处理库)案例代码讲解》本文介绍transformers库的全面讲解,包含基础知识、高级用法、案例代码及学习路径,内容经过组织,适合不同阶段的学习者,对... 目录一、基础知识1. Transformers 库简介2. 安装与环境配置3. 快速上手示例二、核心模

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基

一文详解Java异常处理你都了解哪些知识

《一文详解Java异常处理你都了解哪些知识》:本文主要介绍Java异常处理的相关资料,包括异常的分类、捕获和处理异常的语法、常见的异常类型以及自定义异常的实现,文中通过代码介绍的非常详细,需要的朋... 目录前言一、什么是异常二、异常的分类2.1 受检异常2.2 非受检异常三、异常处理的语法3.1 try-

Python使用getopt处理命令行参数示例解析(最佳实践)

《Python使用getopt处理命令行参数示例解析(最佳实践)》getopt模块是Python标准库中一个简单但强大的命令行参数处理工具,它特别适合那些需要快速实现基本命令行参数解析的场景,或者需要... 目录为什么需要处理命令行参数?getopt模块基础实际应用示例与其他参数处理方式的比较常见问http

Java Response返回值的最佳处理方案

《JavaResponse返回值的最佳处理方案》在开发Web应用程序时,我们经常需要通过HTTP请求从服务器获取响应数据,这些数据可以是JSON、XML、甚至是文件,本篇文章将详细解析Java中处理... 目录摘要概述核心问题:关键技术点:源码解析示例 1:使用HttpURLConnection获取Resp

C 语言中enum枚举的定义和使用小结

《C语言中enum枚举的定义和使用小结》在C语言里,enum(枚举)是一种用户自定义的数据类型,它能够让你创建一组具名的整数常量,下面我会从定义、使用、特性等方面详细介绍enum,感兴趣的朋友一起看... 目录1、引言2、基本定义3、定义枚举变量4、自定义枚举常量的值5、枚举与switch语句结合使用6、枚

使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)

《使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)》PPT是一种高效的信息展示工具,广泛应用于教育、商务和设计等多个领域,PPT文档中常常包含丰富的图片内容,这些图片不仅提升了... 目录一、引言二、环境与工具三、python 提取PPT背景图片3.1 提取幻灯片背景图片3.2 提取

Java中Switch Case多个条件处理方法举例

《Java中SwitchCase多个条件处理方法举例》Java中switch语句用于根据变量值执行不同代码块,适用于多个条件的处理,:本文主要介绍Java中SwitchCase多个条件处理的相... 目录前言基本语法处理多个条件示例1:合并相同代码的多个case示例2:通过字符串合并多个case进阶用法使用

Java实现优雅日期处理的方案详解

《Java实现优雅日期处理的方案详解》在我们的日常工作中,需要经常处理各种格式,各种类似的的日期或者时间,下面我们就来看看如何使用java处理这样的日期问题吧,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言一、日期的坑1.1 日期格式化陷阱1.2 时区转换二、优雅方案的进阶之路2.1 线程安全重构2