手机号码去掉‘86’或‘+86’及点击备注崩溃解决办法

做项目用到通讯录调用,一般的对手机号码校验就不说了,无非就是首位为1,长度11等等,这里说一下校验之后如何对手机号去掉‘86’或‘+86’,直接看代码吧
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
- ( NSString *)formatPhoneNum:( NSString *)phone
{
     if ([phone hasPrefix:@ "86" ]) {
         NSString *formatStr = [phone substringWithRange: NSMakeRange (2, [phone length]-2)];
         return formatStr;
     }
     else if ([phone hasPrefix:@ "+86" ])
     {
         if ([phone hasPrefix:@ "+86·" ]) {
             NSString *formatStr = [phone substringWithRange: NSMakeRange (4, [phone length]-4)];
             return formatStr;
         }
         else
         {
             NSString *formatStr = [phone substringWithRange: NSMakeRange (3, [phone length]-3)];
             return formatStr;
         }
     }
     return phone;
}


手机号码去掉‘-’和去空格后,对于有“+86”的手机号会变成“+86·158xxxxxxxx”(示例),因此要去掉“+86·”才是我们想要的正确手机号

特别特别特别需要注意的一点:上面代码中的“·”可能匹配不到“+86”后面的“·”,你最好先把你要处理的“+86·158xxxxxxxx”打印出来,再把里面的“·”复制粘贴,避免出错或匹配不出来。

对于点击备注崩溃的问题,我常用的有两个办法,一个办法是不展示,另一个办法是展示了但不响应点击事件,只说下后面这种处理方式,在
?
1
-( BOOL )peoplePickerNavigationController:(ABPeoplePickerNavigationController *)peoplePicker shouldContinueAfterSelectingPerson:(ABRecordRef)person property:(ABPropertyID)property identifier:(ABMultiValueIdentifier)identifier

下面添加如下代码即可:
?
1
2
3
if (property == kABPersonNoteProperty) {
         return NO ;
     }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Hive SQL 中,可以使用 `trim()` 函数去除字符串中的空格,并使用正则表达式 `^(86)?1\\d{10}$` 匹配手机号。 示例代码: ``` SELECT * FROM table WHERE trim(phone) REGEXP '^(86)?1\\d{10}$' ``` 其中 `table` 是需要查询的表,`phone` 是手机号字段。 这个正则表达式是匹配手机号的, ^(86)?1\\d{10}$ 这个正则表达式是匹配以86开头的手机号和1开头的手机号的 ### 回答2: 使用Hive SQL编写代码来去除手机号字段中的空格后进行匹配,包括86开头的手机号。下面给出一个示例代码: ```sql SELECT phone_number FROM your_table WHERE regexp_replace(phone_number, ' ', '') RLIKE '^86?\\d{11}$' ``` 解释: - `your_table`是你要查询的表名。 - `phone_number`是手机号字段的列名。 - `regexp_replace(phone_number, ' ', '')`用于替换手机号字段中的空格为空字符串。 - `RLIKE '^86?\\d{11}$'`用于匹配去除空格后的手机号是否合规。其中,`^86?`表示以可选的'86'开头,`\\d{11}`表示接下来的11位数字(总共11位数字)。 - 查询结果将返回符合条件的手机号。 需要注意的是,手机号需满足以下条件: - 号码中可以包含空格,例如:`'139 1234 5678'`。 - 号码可以以'86'开头,例如:`'8613912345678'`。 此代码可帮助你筛选出匹配规则的手机号,包括去除空格后开头为'86'的手机号。 ### 回答3: 在Hive SQL中,可以使用正则表达式函数进行手机号字段的去除空格和匹配。下面是一个示例代码: ```sql SELECT * FROM your_table WHERE regexp_replace(your_phone_number_column, '\\s+', '') RLIKE '^((\\+?86)|0)?1\\d{10}$' ``` 上述代码中,假设手机号字段存储在`your_table`表中的`your_phone_number_column`列中。首先,使用`regexp_replace`函数去除手机号字段中的所有空格,`\\s+`表示匹配一个或多个空格。 接着,使用`RLIKE`关键字进行正则表达式匹配。正则表达式`'^((\\+?86)|0)?1\\d{10}$'`用于匹配手机号码。其中,`^`表示开头,`((\\+?86)|0)?`表示匹配0或1次+86或0,`1`表示数字1,`\\d{10}`表示匹配10个数字,`$`表示结尾。 这样,以上代码将返回匹配手机号的记录,包括以86开头的手机号和去除空格后的手机号。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值