¿Alguien puede señalarme algún recurso sobre la comparación entre mayúsculas y minúsculas en el Objetivo C? No parece tener un método equivalente parastr1.equalsIgnoreCase(str2)
¿Alguien puede señalarme algún recurso sobre la comparación entre mayúsculas y minúsculas en el Objetivo C? No parece tener un método equivalente parastr1.equalsIgnoreCase(str2)
Respuestas:
if( [@"Some String" caseInsensitiveCompare:@"some string"] == NSOrderedSame ) {
// strings are equal except for possibly case
}
La documentación se encuentra en Métodos de búsqueda y comparación.
NSString
que devuelve un valor booleano. Entonces, si la cadena receptora es nil
, el método en su conjunto regresa NO
.
NSString *stringA;
NSString *stringB;
if (stringA && [stringA caseInsensitiveCompare:stringB] == NSOrderedSame) {
// match
}
Nota: stringA &&
es obligatorio porque cuando stringA
es nil
:
stringA = nil;
[stringA caseInsensitiveCompare:stringB] // return 0
y así sucede NSOrderedSame
también se define como 0
.
El siguiente ejemplo es un escollo típico:
NSString *rank = [[NSUserDefaults standardUserDefaults] stringForKey:@"Rank"];
if ([rank caseInsensitiveCompare:@"MANAGER"] == NSOrderedSame) {
// what happens if "Rank" is not found in standardUserDefaults
}
Una alternativa si desea más control que solo la insensibilidad a mayúsculas y minúsculas es:
[someString compare:otherString options:NSCaseInsensitiveSearch];
La búsqueda numérica y la insensibilidad diacrítica son dos opciones útiles.
if ([someString compare:otherString options:NSCaseInsensitiveSearch] && someString.length > 0 && someString != (id)[NSNull null])
Siempre puede asegurarse de que estén en el mismo caso antes de la comparación:
if ([[stringX uppercaseString] isEqualToString:[stringY uppercaseString]]) {
// They're equal
}
El principal beneficio es que evita el problema potencial descrito por matm con respecto a la comparación de cadenas nulas. Puede verificar si la cadena no es nula antes de hacer uno de los compare:options:
métodos, o podría ser vago (como yo) e ignorar el costo adicional de crear una nueva cadena para cada comparación (que es mínimo si solo está haciendo uno) o dos comparaciones).
caseInsensitiveCompare
), use siempre eso.
- (NSComparisonResult)caseInsensitiveCompare:(NSString *)aString
Una nueva forma de hacer esto. iOS 8
let string: NSString = "Café"
let substring: NSString = "É"
string.localizedCaseInsensitiveContainsString(substring) // true
true
para "Café" y "É", esta definitivamente NO es una respuesta correcta.
Convirtiendo la respuesta de Jason Coco a Swift para los profundamente perezosos :)
if ("Some String" .caseInsensitiveCompare("some string") == .OrderedSame)
{
// Strings are equal.
}
En macOS, simplemente puede usar -[NSString isCaseInsensitiveLike:]
, que devuelve BOOL
igual que -isEqual:
.
if ([@"Test" isCaseInsensitiveLike: @"test"])
// Success
NSMutableArray *arrSearchData;
NSArray *data=[arrNearByData objectAtIndex:i];
NSString *strValue=[NSString stringWithFormat:@"%@", [data valueForKey:@"restName"]];
NSRange r = [strValue rangeOfString:key options:NSCaseInsensitiveSearch];
if(r.location != NSNotFound)
{
[arrSearchData addObject:data];
}
@"Some String"
se recibe de cualquier otra llamada y pasa a sernil
, a suif
darétrue
como el envíocaseInsensitiveCompare
anil
es válida y resultados en otronil
, que, en nuestro caso, en comparación conNSOrderedSame
devolverátrue
(NSOrderedSame
se define como 0). Esto puede ser una fuente de errores bastante devastadores, como lo fue en mi caso. ¡Salud!