Swift 的 NSNotFound

NSNotFound for Swift

我通过 Antony 找到了这个验证 URL 的解决方案。

- (BOOL)isValidURL {
    NSUInteger length = [self length];
    // Empty strings should return NO
    if (length > 0) {
       NSError *error = nil;
       NSDataDetector *dataDetector = [NSDataDetector dataDetectorWithTypes:NSTextCheckingTypeLink error:&error];
       if (dataDetector && !error) {
          NSRange range = NSMakeRange(0, length);
          NSRange notFoundRange = (NSRange){NSNotFound, 0};
          NSRange linkRange = [dataDetector rangeOfFirstMatchInString:self options:0 range:range];
          if (!NSEqualRanges(notFoundRange, linkRange) && NSEqualRanges(range, linkRange)) {
             return YES;
          }
       }
       else {
          NSLog(@"Could not create link data detector: %@ %@", [error localizedDescription], [error userInfo]);
       }
    }
    return NO;
}

我想尝试一下,但我正在 swift 中编码。 这是我目前所拥有的。

extension String{
    func isValidURL() -> Bool{
         let length:Int = self.characters.count
         var err:NSError? = nil
         let dataDetector:NSDataDetector?
         do{
             dataDetector = try NSDataDetector(types: NSTextCheckingType.Link.rawValue)
         }catch{
             err = error as? NSError
         }
         if dataDetector != nil && err != nil{
             let range = NSMakeRange(0, length)
             let notFoundRange = (NSRange){ NSNotFound, 0 } //How do I format this for swift?
             let linkRange = dataDetector?.rangeOfFirstMatchInString(self, options: 0, range: range)
             if !NSEqualRanges(notFoundRange, linkRange) && NSEqualRanges(range, linkRange){
                 return true
             }
         }else{
            print("Could not create link data detector: \(err?.localizedDescription): \(err?.userInfo)")
         }

         return false
     }
 }

绊脚石是 NSNotFound。据我所知,这就是 swift 选项的用途。如何格式化该行?

它只是 C 中结构的 aggregate initialization 语法。您可以改用 NSRange 初始化器:

let notFoundRange = NSRange(location: NSNotFound, length: 0)

或者,也许更简单:

if linkRange.location != NSNotFound { ...

对于那些感兴趣的人,这里是使用 jtbandes answer 在 swift 中工作的相同功能。我已经在一堆 URL 上试过了。看起来效果不错..

extension String{
    func isValidURL() -> Bool{
        let length:Int = self.characters.count
        var err:NSError?
        var dataDetector:NSDataDetector? = NSDataDetector()
        do{
            dataDetector = try NSDataDetector(types: NSTextCheckingType.Link.rawValue)
        }catch{
            err = error as NSError
        }
        if dataDetector != nil{
            let range = NSMakeRange(0, length)
            let notFoundRange = NSRange(location: NSNotFound, length: 0)
            let linkRange = dataDetector?.rangeOfFirstMatchInString(self, options: NSMatchingOptions.init(rawValue: 0), range: range)
            if !NSEqualRanges(notFoundRange, linkRange!) && NSEqualRanges(range, linkRange!){
                return true
            }
        }else{
            print("Could not create link data detector: \(err?.localizedDescription): \(err?.userInfo)")
        }

        return false
    }
}