iOS字符串截取每次都会很烦,于是我写了个分类.直接拖入项目就成
不用再算字符位置,也无需担忧截取越界
它可以实现:
(1)截取字符中间某两个字符之间的内容
(2)截掉结尾不要的内容
(3)截掉开头不要的内容
NSString *str = @"ohhh我有一头小毛驴它叫起来yiyayi";
//截取汉字部分
NSString *str1 = [str selcteStringWithSelectSatrt:@"ohhh" selecteEnd:@"yiyayi"];
//截取 小毛驴
NSString *str2 = [str selcteStringWithSelectSatrt:@"一头" selecteEnd:@"它"];
//截掉结尾yiyayi
NSString *str3 = [str selcteStringWithSelectSatrt:nil selecteEnd:@"yiyayi"];
//截掉开头ohhh
NSString *str4 = [str selcteStringWithSelectSatrt:@"ohhh" selecteEnd:nil];
NSLog(@"\nstr1:%@\nstr2:%@\nstr3:%@\nstr4:%@\n",str1,str2,str3,str4);
#import "NSString+SelectString.h"
@implementation NSString (SelectString)
/*
startStr 要从哪几个字符开始截取,如果从第0个字符开始截,输入nil或@""
endStr 要从哪几个字符结束,如果截到最后输入nil或@""
例: 我喜欢abc123还有跳跳跳舞 startStr:欢a endStr:有跳跳 输出结果是:bc123还
*/
- (NSString *)selcteStringWithSelectSatrt:(NSString *)startStr selecteEnd:(NSString *)endStr {
NSString *startRegStr = [startStr stringByReplacingOccurrencesOfString:@"[" withString:@"\\["];//转义[
NSString *endRegStr = [endStr stringByReplacingOccurrencesOfString:@"[" withString:@"\\["];//转义[
NSString *regStr = [NSString stringWithFormat:@"%@.*?%@",startRegStr,endRegStr];//拼接正则字符
if (endStr.length == 0 ) {
regStr = [NSString stringWithFormat:@"%@.*",startRegStr];
}
if (startStr.length == 0) {
regStr = [NSString stringWithFormat:@".*?%@",endStr];
}
//正则方法截取字符串
NSRange codeRange = [self rangeOfString:regStr options:NSRegularExpressionSearch];
NSString *return_code;
if (codeRange.location != NSNotFound){
return_code = [self substringWithRange:codeRange];
if (startStr.length) {
return_code = [return_code stringByReplacingOccurrencesOfString:startStr withString:@""];
}
if (endStr.length) {
return_code = [return_code stringByReplacingOccurrencesOfString:endStr withString:@""];
}
}else{
return_code = @"字符串截取失败";
}
return return_code;
}
/*
. 元字符可以匹配包括他自己的任何字符
\ 转义字符 可以转义 . [ 字符
[ 和]字符 [0-9] 等价于 [0123456789]
+ 字符 : 一个字符一次或者多次重复出现 [0-9]+ 表示大于等于1的一堆数字,
+ 是元字符, 匹配他自己要使用转义符, \+
* 字符, 和+用法完全相同,表示 0个到多个 >= 0的意思
?字符, 匹配0个或者一个 >=0 && <= 1
[ 是正则里的和字符,有特殊含义,如果文字出现这种字符需要加\变成\[转义, 但\在oc里是特殊的转义字符, 所以还需要对\进行转义,就变成了\\[
.*? 正则里.是元字符可以匹配任何字符 .*是贪婪型字符, 如果稳重出现多次 相同字符串,他会全部匹配出来 .*?是懒惰型字符, 如果文中有多个重复字符,他只会匹配第一个出来
例: 123uYku7 用.*匹配u 会输出两个字符串:u和u, 用.*?匹配u 会输出一个字符串:u
*/