Che*_*Lai 47 string iphone alphanumeric objective-c
我正在开发一个小型iphone项目,我需要检查输入的userName是否只包含字母数字字符?(A-Z, a-z, 0-9
.我该如何检查呢?
Jas*_*wig 86
如果您不想为这一项任务引入正则表达式库...
NSString *str = @"aA09";
NSCharacterSet *alphaSet = [NSCharacterSet alphanumericCharacterSet];
BOOL valid = [[str stringByTrimmingCharactersInSet:alphaSet] isEqualToString:@""];
Run Code Online (Sandbox Code Playgroud)
NSR*_*der 61
这将有效:
@implementation NSString (alphaOnly)
- (BOOL) isAlphaNumeric
{
NSCharacterSet *unwantedCharacters =
[[NSCharacterSet alphanumericCharacterSet] invertedSet];
return ([self rangeOfCharacterFromSet:unwantedCharacters].location == NSNotFound);
}
@end
Run Code Online (Sandbox Code Playgroud)
在NSCharacterSet
基于答案不给你所期望的日本等文本的结果,往往声称他们确实包含字母数字字符-被执行的测试归结为"在那里只有字母或数字",以及日本(等)字符算作"快报.
如果您正在尝试检查拉丁字符与外语(例如日语),那么" 如何确定NSString是否基于拉丁语? " 的答案可能会有所帮助:
BOOL isLatin = [myString canBeConvertedToEncoding:NSISOLatin1StringEncoding];
Run Code Online (Sandbox Code Playgroud)
NSASCIIStringEncoding
也可以用来代替NSISOLatin1StringEncoding来进一步限制有效字符.您也可以在之后使用NSCharacterSet进行测试,以排除特殊字符,如!,#等.
我已经进行了一些相当广泛的性能测试,在选择如何验证字母数字字符串时需要考虑几个因素.首先,当然,你可能甚至不关心表现.如果您的应用程序很少验证字符串,或者甚至只执行一次,那么无论采用哪种方法,您都可以获得所需的行为.除此之外,这是我的表现结果.
对于自定义字符集(例如字母数字字符,不包含Unicode字符或标记),这对于初始运行来说速度最快:
NSCharacterSet *alphanumericSet = [NSCharacterSet characterSetWithCharactersInString:@"abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890"];
NSString *result = [self stringByTrimmingCharactersInSet:alphanumericSet];
return [result isEqualToString:@""];
Run Code Online (Sandbox Code Playgroud)
如果你可以使用像那样的预先计算的字符集[NSCharacterSet alphanumericCharacterSet]
这是最快的:
NSCharacterSet *alphanumericSet = [NSCharacterSet alphanumericCharacterSet];
alphanumericSet = alphanumericSet.invertedSet;
NSRange range = [self rangeOfCharacterFromSet:alphanumericSet];
return (range.location == NSNotFound);
Run Code Online (Sandbox Code Playgroud)
dispatch_once
如果重复运行这些验证,使用静态变量缓存字符集可能会有所帮助.在这种情况下,如果您确定可以吸收初始编译时间,那么使用正则表达式实际上是自定义字符集的最快速度:
static NSRegularExpression *alphanumericRegex;
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
alphanumericRegex = [NSRegularExpression regularExpressionWithPattern:@"^[a-zA-Z0-9]*$" options:NSRegularExpressionCaseInsensitive error:nil];
});
NSUInteger numberOfMatches = [alphanumericRegex numberOfMatchesInString:self options:0 range:NSMakeRange(0, self.length)];
return (numberOfMatches == 1);
Run Code Online (Sandbox Code Playgroud)
如果您不希望使用正则表达式,则缓存的自定义集版本将缓存rangeOfCharacterFromSet
出来stringByTrimmingCharactersInCharacterSet:
:
static NSCharacterSet *alphanumericSet;
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
alphanumericSet = [NSCharacterSet characterSetWithCharactersInString:@"abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890"];
alphanumericSet = alphanumericSet.invertedSet;
});
NSRange range = [self rangeOfCharacterFromSet:alphanumericSet];
return (range.location == NSNotFound);
Run Code Online (Sandbox Code Playgroud)
对于预先计算的集合,缓存的rangeOfCharacterFromSet:
方法再次是最快的:
static NSCharacterSet *alphanumericSet;
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
alphanumericSet = [NSCharacterSet alphanumericCharacterSet];
alphanumericSet = alphanumericSet.invertedSet;
});
NSRange range = [self rangeOfCharacterFromSet:alphanumericSet];
return (range.location == NSNotFound);
Run Code Online (Sandbox Code Playgroud)
并且对于每个人的信息,该isSupersetOfSet:
方法是最慢的,无论是否缓存.看起来isSupersetOfSet:
很慢.
NSCharacterSet *stringSet = [NSCharacterSet characterSetWithCharactersInString:self];
NSCharacterSet *alphanumericSet = [NSCharacterSet alphanumericCharacterSet];
return [alphanumericSet isSupersetOfSet:stringSet];
Run Code Online (Sandbox Code Playgroud)
我没有对底层的CFCharacterSet函数进行任何测试.
归档时间: |
|
查看次数: |
48932 次 |
最近记录: |