常用正则表达式—邮箱(Email)

 要验证一个字符串是否为邮箱的话,首先要了解邮箱账号的格式。我尝试过在网上找出一个标准的格式,但是很遗憾我没有找到。我也尝试使用RFC标准来判断邮箱的格式,但是也没有结果。网上些博客说不应该使用RFC标准来验证邮箱是否合法,有兴趣的可以看看“is this email valid?”和“Don’t RFC-Validate Email Addresses”。据了解【参考】,现在用中文命名的邮箱也合法了,比如“杨元庆@联想.中国”。

 虽然没有统一的邮箱账号格式,但是所有邮箱都符合“名称@域名”的规律。对于名称和域名的字符限制,我们可以根据项目的情况定义一个,比如只允许有英文、数字、下划线等组成。下面举例实现一些验证邮箱格式的正则表达式。

实例1、只允许英文字母、数字、下划线、英文句号、以及中划线组成

举例:zhangsan-001@gmail.com

分析邮件名称部分:

  • 26个大小写英文字母表示为a-zA-Z
  • 数字表示为0-9
  • 下划线表示为_
  • 中划线表示为-

由于名称是由若干个字母、数字、下划线和中划线组成,所以需要用到+表示多次出现

  • 根据以上条件得出邮件名称表达式:[a-zA-Z0-9_-]+

分析域名部分:

 一般域名的规律为“[N级域名][三级域名.]二级域名.顶级域名”,比如“qq.com”、“www.qq.com”、“mp.weixin.qq.com”、“12-34.com.cn”,分析可得域名类似“** .** .** .”组成。“”部分可以表示为[a-zA-Z0-9_-]+

“.”部分可以表示为.[a-zA-Z0-9_-]+多个“.”可以表示为(.[a-zA-Z0-9_-]+)+

 综上所述,域名部分可以表示为[a-zA-Z0-9_-]+(.[a-zA-Z0-9_-]+)+

最终表达式:由于邮箱的基本格式为“名称@域名”,需要使用“^”匹配邮箱的开始部分,用“$”匹配邮箱结束部分以保证邮箱前后不能有其他字符,所以最终邮箱的正则表达式为:

  ^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(.[a-zA-Z0-9_-]+)+$

实例2、名称允许汉字、字母、数字,域名只允许英文域名

举例:杨元庆001Abc@lenovo.com.cn

分析邮件名称部分:

  • 汉字在正则表示为[\u4e00-\u9fa5]
  • 字母和数字表示为A-Za-z0-9
  •  通过分析得出邮件名称部分表达式为[A-Za-z0-9\u4e00-\u9fa5]+

分析邮件域名部分

  •  邮件部分可以参考实例1中的分析域名部分。
  •  得出域名部分的表达式为[a-zA-Z0-9_-]+(.[a-zA-Z0-9_-]+)+

最终表达式:我们用@符号将邮箱的名称和域名拼接起来,因此完整的邮箱表达式为

  ^[A-Za-z0-9\u4e00-\u9fa5]+@[a-zA-Z0-9_-]+(.[a-zA-Z0-9_-]+)+$

题目 

测试数据及结果  mysql

DROP TABLE IF EXISTS `client_into`;
CREATE TABLE `client_into`  (`Emall` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,`result` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL
);
INSERT INTO `client_into` VALUES ('17562+343284@qq.com', NULL);
INSERT INTO `client_into` VALUES ('www.ingdsf@163.com', NULL);
INSERT INTO `client_into` VALUES ('s-adyfs@cloud.com', NULL);
INSERT INTO `client_into` VALUES ('sfdffad+@cloud.cn', NULL);
INSERT INTO `client_into` VALUES ('www.ugsd87345.com', NULL);
INSERT INTO `client_into` VALUES (NULL, NULL);
INSERT INTO `client_into` VALUES ('4 8dfsaf@qq.com', NULL);
INSERT INTO `client_into` VALUES ('q******@qq.com', NULL);
INSERT INTO `client_into` VALUES ('dfhysd_@126.com', NULL);
INSERT INTO `client_into` VALUES ('sfdffad@cloud.cn.cn', NULL);SELECT emall,case when emall REGEXP '^[a-zA-Z0-9]+[.+-]+[a-zA-Z0-9]+@[a-zA-Z0-9.-]+\.[a-zA-Z0-9.-]+$' then '符合' else '不符合' end as result FROM `client_into`;

关于邮箱的正则表达式相关推荐

  1. java正则完美匹配注释_匹配Email邮箱的正则表达式(完美经典)

    匹配Email邮箱格式的正则表达式: /^[a-z]([a-z0-9]*[-_]?[a-z0-9]+)*@([a-z0-9]*[-_]?[a-z0-9]+)+[\.][a-z]{2,3}([\.][a ...

  2. JS:关于邮箱的正则表达式及规则

    常用正则表达式-邮箱(Email) 要验证一个字符串是否为邮箱的话,首先要了解邮箱账号的格式.我尝试过在网上找出一个标准的格式,但是很遗憾我没有找到.我也尝试使用RFC标准来判断邮箱的格式,但是也没有 ...

  3. 判断邮箱的正则表达式

    判断邮箱的正则表达式 邮箱@前缀的几种类型: 1.纯数字       123456@qq.com  2.纯字母 zhangsan@qq.com 3.字母数字混合  zhang123@qq.com 4. ...

  4. java邮箱地址正则表达式_JAVA 电子邮箱格式验证,使用正则表达式

    正则表达式 正则表达式(regular expression)描述了一种字符串匹配的模式(pattern),能够用来检查一个串是否含有某种子串.将匹配的子串替换或者从某个串中取出符合某个条件的子串等. ...

  5. js 正则匹配邮箱_日常收集JS邮箱验证正则表达式

    背景:正则是一门厚书啊,想写好也不容易,但日常中也就那些像电话.邮箱.手机,网上一堆,但真好验证好了,还得了解一点正则知识,再就是多测试了:-) 下面邮箱正则: 中划线:中划线域名就是米农口中说的扁担 ...

  6. 正则表达式匹配邮箱 php,php中匹配邮箱地址正则表达式

    一篇php中匹配邮箱地址正则表达式实例,邮箱地址替换正则我常用的正则匹配表达式:/^[a-z]([a-z0-9]*[-_]?[a-z0-9]+)*@([a-z0-9]*[-_]?[a-z0-9]+)+ ...

  7. linux邮箱格式正则表达式,【深入浅出Linux】常用正则表达式校验

    前言 使用man grep查看grep的帮助文档,有如下内容: image 可以看出,正则表达式由三类,分别是 基本的正则表达式(Basic Regular Expression 又叫 Basic R ...

  8. PHP中邮箱地址的正则表达式,php邮箱地址正则表达式实现与详解,邮箱地址正则表达式_PHP教程...

    php邮箱地址正则表达式实现与详解,邮箱地址正则表达式 本文章不但要讲述了关于正则达式而且还讲述了关于邮箱正则的构成用法详解,有需要了解的朋友可以参考一下,同时我们也提供了多种不同的邮箱验证实例. 正 ...

  9. php 邮箱验证正则表达式,php邮箱地址正则表达式验证

    我们最经常遇到的验证,就是电子邮件地址验证.网站上常见.各种网页脚本也都常用"正则表达式"(regular expression)对我们输入的电子邮件地址进行验证,判断是否合法.有 ...

  10. php正则邮箱验证,两种PHP用户注册邮箱验证正则表达式方法

    一般我们在WEB端新注册或者登陆账户的时候,对于字段的验证不仅仅是需要验证其是否为空或者长度,有些特殊的字段,比如EMAIL邮箱我们需要验证是不是邮箱的格式,比如是都带有@符号等.刚才在练习PHP程序 ...

最新文章

  1. SQL SERVER特殊行转列案列一则
  2. 这是我的第一篇博客!
  3. linux mysql 客户端编码设置_Windows、Linux系统下mysql编码设置方法_MySQL
  4. linux之vim操作快速跳到下一个空格和上一个空格命令
  5. PiFlow大数据流水线系统v0.9源码
  6. erl_0015 《硝烟中的erlang》 读书笔记002 “为过载做计划”
  7. c语言全民,C语言还有学习的必要吗
  8. 基于SQL Server策略的管理–类别和数据库订阅
  9. 2021 前端面试经常被问到 Javascript+HTML5+CSS+ 框架问题(89 篇资料总结)
  10. python关闭word_python自动化办公:玩转word之样式秘笈
  11. pyspark to mysql_Pyspark学习笔记第2篇:connect mysql
  12. React Native 画虚线 DashLine
  13. 数电2_2——逻辑函数的变换与化简
  14. rssi参数获取_如何获取WlanGetNetworkBssList函数返回值的Rssi值
  15. 用户画像 客户消费模型表
  16. 语音交互的基本概念和设计实践
  17. 用c语言编写出的情话,c语言for情话
  18. 淘宝购物电话错误危急处理
  19. 如何策划新闻营销的主题?
  20. 认识物联网系列——物联网架构

热门文章

  1. 获取URL中的一级域名
  2. Flutter深色模式适配
  3. 手机端APP防盗链配置问题
  4. 双系统彻底删除Ubuntu启动项
  5. pr如何处理音效_PR剪辑如何让视频声音更好听
  6. matlab中imcrop函数的具体使用
  7. CLUSTERDOWN Hash slot not served 记录一次线上redis插槽问题
  8. redis实现原理和应用(redis读书笔记)
  9. Android 各大市场更改APP名称
  10. 【金融手册】什么是本票、汇票、支票、银行承兑汇票、系统性、非系统性风险、巴塞尔协议、QDII...