Unicode日期格式模式指南(here)指出,对格式附加'a'将获得句点(例如AM或PM),例如,
[formatter setDateFormat:@"yyyy-MM-dd'T'HH:mm:ss a"];
但是,我希望确保没有出现期间信息,但我找不到格式字符串来执行此操作。我使用的格式字符串如下:
[formatter setDateFormat:@"yyyy-MM-dd'T'HH:mm:ss"];
不幸的是,当我使用stringFromDate时,我得到以下内容:
2013-01-09T11:11:00 AM
我不希望简单地从结果字符串中删除AM或PM,因为句点语法在不同的日历等中可能会有所不同,我只想停止出现句号信息。
---- 8< ------
考虑以下代码
NSDateFormatter *formatter = [[NSDateFormatter alloc] init];
[formatter setLocale:[NSLocale currentLocale]];
[formatter setTimeZone:[NSTimeZone timeZoneWithAbbreviation:@"UTC"]];
[formatter setDateFormat:@"yyyy-MM-dd'T'HH:mm:ss"];
NSString *stringDate = [formatter stringFromDate:[NSDate date]];
self.labelOutput.text = stringDate;
[formatter release];
此代码将以我想要的格式生成一个字符串 - 但是我不能将它用于内存管理的原因。我正在处理的应用程序受到NSDateFormatter内存泄漏的困扰。因此,我们使用单例类为应用程序提供一组永远不会释放的固定数量的NSDateFormatters,因此我们最大限度地减少了泄漏的内存量。不幸的是,即使我应用日期格式字符串,这些静态NSDateFormatters也会附加AM / PM:
NSDateFormatter *formatter = [MyDateFormatter dateFormat:kFormatDateMediumStyleTimeShortStyle];
[formatter setTimeZone:[NSTimeZone timeZoneWithAbbreviation:@"UTC"]];
[formatter setDateFormat:@"yyyy-MM-dd'T'HH:mm:ss"];
答案 0 :(得分:5)
根据date formatter different output on different devices running same iOS version,将NSDateFormatter
的本地设置为en_US_POSIX
即可解决此问题。
除了设置本地之外,您可能希望避免时区设置的问题,如: [formatter setTimeZone:[NSTimeZone timeZoneWithAbbreviation:@“UTC”]];
答案 1 :(得分:2)
实际上取决于用户的设置。
请参阅数据格式指南的Fixed Formats部分。请注意这句话:
在iOS中,用户可以覆盖默认的AM / PM与24小时的时间 设置。这可能导致NSDateFormatter重写格式字符串 你设置了。
在段落的末尾:
时间的表示可能是13:00。但是,在iOS中,如果是 用户已将24小时时间切换为关闭,时间可能是下午1:00。
答案 2 :(得分:1)
您需要在此处使用POSIX示例代码
NSDateFormatter *rfc3339DateFormatter = [[NSDateFormatter alloc] init];
NSLocale *enUSPOSIXLocale = [[NSLocale alloc] initWithLocaleIdentifier:@"en_US_POSIX"];
[rfc3339DateFormatter setLocale:enUSPOSIXLocale];
[rfc3339DateFormatter setDateFormat:@"yyyy'-'MM'-'dd'T'HH':'mm':'ss'Z'"];
[rfc3339DateFormatter setTimeZone:[NSTimeZone timeZoneForSecondsFromGMT:0]];
// Convert the RFC 3339 date time string to an NSDate.
NSDate *date = [rfc3339DateFormatter dateFromString:rfc3339DateTimeString];
答案 3 :(得分:0)
一种选择是创建自己的NSFormatter。当我无法在Xcode的Interface Builder中使用格式化程序来执行我想要的操作时,我在代码上执行了该操作。当然,我只是寻找小时,分钟和秒,而不是完整的日期。
至于内存泄漏:如果可以,请使用ARC。如果不能,请使用Xcode的静态分析器尝试追踪不正确的保留计数。
答案 4 :(得分:0)
以下是我已经解决的答案。它有点简单,但它确实起作用。
@interface NSDateFormatter (Utils)
- (NSString *)stringWithNoPeriodInformationFromDate:(NSDate*)date;
@end
@implementation NSDateFormatter (Utils)
- (NSString *)stringWithNoPeriodInformationFromDate:(NSDate*)date
{
NSString *stringWithPotentialPeriodInformation = [self stringFromDate:date];
NSString *stringWithNoAMInformation = [stringWithPotentialPeriodInformation stringByReplacingOccurrencesOfString:[self AMSymbol] withString:@""];
NSString *stringWithNoPeriodInformation = [stringWithNoAMInformation stringByReplacingOccurrencesOfString:[self PMSymbol] withString:@""];
return stringWithNoPeriodInformation;
}
@end