IOS 常用正则表达式整理(邮箱、身份证号、固化、手机号、纯数字、纯文字等)

本文主要是介绍IOS 常用正则表达式整理(邮箱、身份证号、固化、手机号、纯数字、纯文字等),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:常用正则表达式整理,包括邮箱、身份证号、固化、手机号、纯数字、纯文字等

一、对邮箱进行校验

+ (BOOL)checkEmail:(NSString *)email
{NSString *emailReg = @"^([a-z0-9A-Z]+[-|\\.]?)+[a-z0-9A-Z]@([a-z0-9A-Z]+(-[a-z0-9A-Z]+)?\\.)+[a-zA-Z]{2,}$";NSPredicate *regextestmobile = [NSPredicate predicateWithFormat:@"SELF MATCHES %@",emailReg];if ([regextestmobile evaluateWithObject:email] == YES){return YES;}return NO;
}


二、对身份证号进行校验

+ (BOOL)checkPersonID:(NSString *)personID
{NSString *person = @"(\\d{14}[0-9a-zA-Z])|(\\d{17}[0-9a-zA-Z])";NSPredicate *regextestmobile = [NSPredicate predicateWithFormat:@"SELF MATCHES %@",person];if ([regextestmobile evaluateWithObject:personID] == YES){return YES;}return NO;
}
三、对固话进行校验

#pragma mark 检验是否是固定电话
+ (BOOL)checkLandlinePhone:(NSString *)landlinePhone
{NSString *mobile = @"0\\d{2,3}-\\d{5,9}|0\\d{2,3}-\\d{5,9}";NSPredicate *regextestmobile = [NSPredicate predicateWithFormat:@"SELF MATCHES %@",mobile];if ([regextestmobile evaluateWithObject:landlinePhone] == YES){return YES;}return NO;
}
四、对手机号进行校验
#pragma mark 检测手机号码是否正确
+ (BOOL)checkMobileNumber:(NSString *)mobileNum{mobileNum = [mobileNum stringByReplacingOccurrencesOfString:@"-" withString:@""];mobileNum = [mobileNum stringByReplacingOccurrencesOfString:@" " withString:@""];if ([mobileNum hasPrefix:@"00"])return NO;if ([mobileNum hasPrefix:@" "]){mobileNum = [mobileNum stringByReplacingOccurrencesOfString:@" " withString:@""];}/*** 手机号码* 移动:134[0-8],135,136,137,138,139,150,151,157,158,159,182,187,188* 联通:130,131,132,152,155,156,185,186* 电信:133,1349,153,180,189** 新增* 移动:152 154 178 183 184* 联通:176* 电信:177 181*/NSString * MOBILE = @"^1(3[0-9]|4[0-9]|5[0-9]|7[67]|8[0-9])\\d{8}$";/**10         * 中国移动:China Mobile11         * 134[0-8],135,136,137,138,139,150,151,152,154,157,158,159,178,182,183,184,187,18812         */NSString * CM = @"^1(34[0-8]|(3[5-9]|5[0-247-9]|7[8]|8[2-478])\\d)\\d{7}$";/**15         * 中国联通:China Unicom16         * 130,131,132,152,155,156,176,185,18617         */NSString * CU = @"^1(3[0-2]|5[256]|7[6]|8[56])\\d{8}$";/**20         * 中国电信:China Telecom21         * 133,1349,153,177,180,181,18922         */NSString * CT = @"^1((33|53|7[7]|8[019])[0-9]|349)\\d{7}$";/**25         * 大陆地区固话及小灵通26         * 区号:010,020,021,022,023,024,025,027,028,02927         * 号码:七位或八位28         */NSString *telNum = @"^0\\d[1-9]{1}(\\d[0-9]{1,2}\\d[1-9]{1})\\d{4,6}";NSPredicate *regextestmobile = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", MOBILE];NSPredicate *regextestcm = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", CM];NSPredicate *regextestcu = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", CU];NSPredicate *regextestct = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", CT];NSPredicate *regextestTel = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", telNum];if ([regextestTel evaluateWithObject:mobileNum]){MyLog(@"pass");}if (([regextestmobile evaluateWithObject:mobileNum] == YES)|| ([regextestcm evaluateWithObject:mobileNum] == YES)|| ([regextestct evaluateWithObject:mobileNum] == YES)|| ([regextestcu evaluateWithObject:mobileNum] == YES)|| ([regextestTel evaluateWithObject:mobileNum] == YES)){return YES;}return NO;
}

五、纯数字

NSString *reg = @"^\\d*$";
六、纯字母

NSString *reg = @"^[A-Za-z]*$";
七、首字母为字母,其它为A-Za-z_0-9
NSString *reg = @"^[a-zA-Z]\\w{1,}$";





这篇关于IOS 常用正则表达式整理(邮箱、身份证号、固化、手机号、纯数字、纯文字等)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1018230

相关文章

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

Java中Arrays类和Collections类常用方法示例详解

《Java中Arrays类和Collections类常用方法示例详解》本文总结了Java中Arrays和Collections类的常用方法,涵盖数组填充、排序、搜索、复制、列表转换等操作,帮助开发者高... 目录Arrays.fill()相关用法Arrays.toString()Arrays.sort()A

Python自动化批量重命名与整理文件系统

《Python自动化批量重命名与整理文件系统》这篇文章主要为大家详细介绍了如何使用Python实现一个强大的文件批量重命名与整理工具,帮助开发者自动化这一繁琐过程,有需要的小伙伴可以了解下... 目录简介环境准备项目功能概述代码详细解析1. 导入必要的库2. 配置参数设置3. 创建日志系统4. 安全文件名处

MySQL 迁移至 Doris 最佳实践方案(最新整理)

《MySQL迁移至Doris最佳实践方案(最新整理)》本文将深入剖析三种经过实践验证的MySQL迁移至Doris的最佳方案,涵盖全量迁移、增量同步、混合迁移以及基于CDC(ChangeData... 目录一、China编程JDBC Catalog 联邦查询方案(适合跨库实时查询)1. 方案概述2. 环境要求3.

SpringSecurity整合redission序列化问题小结(最新整理)

《SpringSecurity整合redission序列化问题小结(最新整理)》文章详解SpringSecurity整合Redisson时的序列化问题,指出需排除官方Jackson依赖,通过自定义反序... 目录1. 前言2. Redission配置2.1 RedissonProperties2.2 Red

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

Javaee多线程之进程和线程之间的区别和联系(最新整理)

《Javaee多线程之进程和线程之间的区别和联系(最新整理)》进程是资源分配单位,线程是调度执行单位,共享资源更高效,创建线程五种方式:继承Thread、Runnable接口、匿名类、lambda,r... 目录进程和线程进程线程进程和线程的区别创建线程的五种写法继承Thread,重写run实现Runnab