我正在将字符串“2012 年 6 月 11 日晚上 9:30”转换为 NSDate,但由于某种原因,我一直提前 4 小时。有趣的是,我正在使用相同的字符串在详细 View 中提供 UIDatePicker,我必须在其中进行相同的转换,并且 UIDatePicker 可以很好地呈现时间。只有当我现在尝试在我的主视图和详细 View 中对其进行 NSLog 记录时,我才会遇到问题。
这是我的看法:
NSDateFormatter *formatter = [[NSDateFormatter alloc] init];
[formatter setDateFormat"MMMM dd, yyyy h:mma"];
NSDate *dateFromString = [[[NSDate alloc] init]autorelease];
NSLog(@"DATE %@", _date);
dateFromString = [formatter dateFromString:_date];
NSLog(@"NSDATEFROMSTRING %@", dateFromString);
NSLog 返回:
2012-06-11 00:02:09.136 LocalDeals[78090:207] DATE Jun 11, 2012 9:30 PM
2012-06-11 00:02:09.137 LocalDeals[78090:207] NSDATEFROMSTRING 2012-06-12 01:30:00 +0000
即使我添加:
[formatter setTimeZone:[NSTimeZone defaultTimeZone]];
在我选择的任何时候,我仍然会得到相同的结果。有任何想法吗?顺便说一句,这是在模拟器上,是的,我的区域格式设置为美国。
当您 NSLog 一个 NSDate 时,它会将时间打印为 GMT 时区
为了查看正确的数据,您必须使用 stringFromDate
NSDate *dateFromString = [[[NSDate alloc] init]autorelease];
NSLog(@"DATE %@", _date);
//Instead of nslog directly, use this stringFromDate:remindOn
NSString *str = [formatter stringFromDate:dateFromString];
NSLog(@"date is %@", str); //This will log the correct data
您遇到的问题不在 NSDate 中,而是在记录它 更新为了将数据保存到文件或数据库中,我建议您这样保存
NSTimeInterval timeInterval = [dateFromString timeIntervalSince1970];
现在,当您再次从数据库中读取它时,您会这样做
NSDate *data = [[NSDate alloc] initWithTimeIntervalSince1970:timeInterval]
关于ios - NSDateFormatter 提前 4 小时给我时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10974496/
欢迎光临 OGeek|极客世界-中国程序员成长平台 (https://ogeek.cn/) | Powered by Discuz! X3.4 |