注意:作为练习,我将Swift代码转换为Objective-C。
代码:我转换的原始Swift代码:
case .ISO8601(let isoFormat):
let dateFormat = (isoFormat != nil) ? isoFormat! : ISO8601Format(dateString: string as String)
let formatter = NSDate.formatter(format: dateFormat.rawValue)
formatter.locale = NSLocale(localeIdentifier: "en_US_POSIX")
formatter.timeZone = NSTimeZone.localTimeZone()
formatter.dateFormat = dateFormat.rawValue
if let date = formatter.dateFromString(string as String) {
self.init(timeInterval:0, sinceDate:date)
} else {
self.init()
}
我做了什么:我尝试过的Objective-C转换:
else if([format.dateFormatType compare: ISO8601DateFormatType] == NSOrderedSame) {
NSString *isoFormat = // WHAT DO TO HERE ?;
NSString *dateFormat = (isoFormat != nil) ? isoFormat : ISO8601DateFormatType;
NSDateFormatter *formatter = [NSDate formatterWithFormat: dateFormat andTimeZone: [NSTimeZone localTimeZone ] andLocale: [NSLocale currentLocale]];
formatter.locale = [NSLocale localeWithLocaleIdentifier: (@"en_US_POSIX")];
NSLog([NSString stringWithFormat:@"%@", dateFormat]);
// dateFormat = ISO8601
NSDate *date = [formatter dateFromString:(string)];
//
// ISSUE IS HERRRREEEE ^
//
NSLog([NSString stringWithFormat:@"%@", date]);
// date = nil
if (date != nil){
return [self initWithTimeInterval: 0 sinceDate: date];
}
else {
return [self init];
}
}
我采用的方法是使用一个单独的类来重现具有相关值的swift枚举的行为(这最初是一个带有相关值的大型快速枚举):
DateFormat.m
#import "DateFormat.h"
@implementation DateFormat
NSString * const ISO8601DateFormatType = @"ISO8601";
NSString * const DotNetDateFormatType = @"DotNet";
NSString * const RSSDateFormatType = @"EEE, d MMM yyyy HH:mm:ss ZZZ";
NSString * const AltRSSDateFormatType = @"d MMM yyyy HH:mm:ss ZZZ";
NSString * const CustomDateFormatType = @"Custom";
NSString * const ISOFormatYear = @"yyyy";
NSString * const ISOFormatYearMonth = @"yyyy-MM"; // 1997-07
NSString * const ISOFormatDate = @"yyyy-MM-dd"; // 1997-07-16
NSString * const ISOFormatDateTime = @"yyyy-MM-dd'T'HH:mmZ"; // 1997-07-16T19:20+01:00
NSString * const ISOFormatDateTimeSec = @"yyyy-MM-dd'T'HH:mm:ssZ"; // 1997-07-16T19:20:30+01:00
NSString * const ISOFormatDateTimeMilliSec = @"yyyy-MM-dd'T'HH:mm:ss.SSSZ"; // 1997-07-16T19:20:30.45+01:00
- (instancetype) initWithType: (NSString *) formatType details: (NSString *) details {
if(self = [super init]) {
_dateFormatType = formatType;
_formatDetails = details;
}
return self;
}
+ (instancetype) ISODateFormat: (NSString *) isoFormat
{
return [[DateFormat alloc] initWithType: ISO8601DateFormatType details: isoFormat];
}
+ (instancetype) DotNetDateFormat
{
return [[DateFormat alloc] initWithType: DotNetDateFormatType details: nil];
}
+ (instancetype) RSSDateFormat
{
return [[DateFormat alloc] initWithType: RSSDateFormatType details: nil];
}
+ (instancetype) AltRSSDateFormat
{
return [[DateFormat alloc] initWithType: AltRSSDateFormatType details: nil];
}
+ (instancetype) CustomDateFormat: (NSString *) formatString
{
return [[DateFormat alloc] initWithType: CustomDateFormatType details: formatString];
}
@end
我的问题:
在我的代码中,dateFromString
返回nil
,因为作为参数传递的格式不正确。发生这种情况的原因是我使用关联的值行转换枚举的方式:case .ISO8601(let isoFormat):
我不知道如何将case .ISO8601(let isoFormat):
转换为Objective-C。
问题是具有关联值的枚举仅存在于Swift中,而不存在于Objective-C中。
那么如何在Objective-C中将关联的值行.ISO8601(let isoFormat):
转换为枚举?
SOLUTION:
编辑:答案很简单,我只需要在问题开头的Objective-C转换中写出:NSString *isoFormat = format.formatDetails;
。 (检查我的类DateFormat实现文件以了解)
答案 0 :(得分:2)
让我为您解释一下代码:
NSString *isoFormat = ISO8601DateFormatType;
(将字符串ISO8601
分配给isoFormat
)
NSString *dateFormat = (isoFormat != nil) ? isoFormat : ISO8601DateFormatType;
(isoFormat
永远不会nil
因此条件始终为真。如果为假,我们将再次分配字符串ISO8601
。
NSDateFormatter *formatter = ...
(我们得到一些格式化程序,因为我们覆盖了所有重要属性并不重要)
formatter.locale = [NSLocale localeWithLocaleIdentifier: (@"en_US_POSIX")];
(让我们用POSIX语言环境覆盖上面的[NSLocale currentLocale]
,没关系)
formatter.timeZone = [NSTimeZone localTimeZone];
(让我们再次设置时区)
formatter.dateFormat = dateFormat;
(让我们将字符串ISO8601
设置为日期格式,这不是有效的日期格式)
NSDate *date = [formatter dateFromString:(string)];
(让我们尝试使用无效的日期格式ISO8601
解析日期。显然,这将返回nil
)
简而言之 - 问题与上一个问题Error in dateFormat returns nil
中的问题完全相同