Reputation: 6066
Does anyone know how to fetch some results sorting them alphabetically but ignoring case?
Upvotes: 31
Views: 8681
Reputation: 551
Swift Version:
let sortDescriptor = NSSortDescriptor(key: "firstName", ascending: true, selector: #selector(NSString.localizedCaseInsensitiveCompare))
Upvotes: 4
Reputation: 6066
Thank you for your reply, but I need to sort the result of a simple "query" ignoring case. Your suggestion applies for searching and comparing.
SQL speaking, I need an ORDER BY firstName ASC
, and this command must be case insensitive for my usage.
I have done some Googling and I ended reading the NSSortDescriptor Class reference, and I could find the answer for my question. The solution is setting a selector to the sort descriptor as follow:
NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"firstName" ascending:YES selector:@selector(caseInsensitiveCompare:)];
I hope it will be useful for more people.
Upvotes: 78
Reputation: 6035
If the app is localized in several languages, please consider using the localizedCaseInsensitiveCompare:
selector instead of caseInsensitiveCompare
. It will have the effect to avoid the letter 'é' to be after the letter 'e'.
NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"firstName" ascending:YES selector:@selector(localizedCaseInsensitiveCompare:)];
Upvotes: 10
Reputation: 85532
Check out the NSPredicate programming guide, but basically use [c] to ignore case:
@"firstName BEGINSWITH[c] $FIRST_NAME"
Upvotes: 5