Maison  >  Article  >  interface Web  >  Explication détaillée de la vérification numérique régulière (avec code)

Explication détaillée de la vérification numérique régulière (avec code)

php中世界最好的语言
php中世界最好的语言original
2018-03-30 14:21:153882parcourir

Cette fois je vous apporte quelles sont les précautionsVoici des cas pratiques.

Partie 1 : Vérification numérique

1 Vérifiez les chaînes contenant uniquement des nombres et la longueur spécifiée (N)

Par exemple, si je souhaite vérifier une chaîne contenant uniquement des chiffres et une longueur de 6, comme 123456, je peux utiliser les méthodes de vérification suivantes avec le même effet

\d{6}
[0-9]{6}
\d\d\d\d\d\d
Les méthodes ci-dessus ont le même effet, et la première est plus recommandée, elle est plus concise ! Remarque : j'utiliserai l'

expression régulière plus concise plus tard, sans être trop verbeuse !

2. Vérifiez que la chaîne de mots contient uniquement des chiffres et spécifie la longueur de la plage (N-M)

Par exemple, je souhaite vérifier qu'elle ne contient que des chiffres et le la longueur est comprise entre 5 et 8 chaînes, telles que 12345, 123456, 1234567, 12345678, vous pouvez utiliser la méthode de vérification

3.

Évidemment 0, 100, 56, etc. sont tous des entiers non négatifs, tandis que -12, 0135, etc. ne sont pas des entiers non négatifs. La démonstration de vérification est la suivante :

                                                                                                                                                                                              56 ne sera pas sélectionné car il ne s'agit pas d'un nombre positif. (Remarque : ^ est utilisé, ce qui signifie qu'il doit commencer par 0 ou [1-9], donc -56 n'est pas sélectionné ; s'il n'y a pas de ^, alors 56 dans -56 sera sélectionné)

4. Vérification des entiers arbitraires

Entiers arbitraires tels que 0, 456, -65, etc. Ce sont des entiers arbitraires, ce qui signifie que nous devons combiner des nombres positifs et des entiers non négatifs. La démonstration de vérification est la suivante :

 

Ainsi, tous les nombres positifs, y compris 0, les entiers positifs et les entiers négatifs correspondent.

5. Vérification des entiers positifs dans la plage spécifiée

Par exemple, nous voulons vérifier les entiers positifs dans la plage de 1 à 5678, tels que 465, 23 , 5677, etc. Il appartient à cette gamme, comment le vérifier ? Ne vous inquiétez pas, nous pouvons vérifier entre les partitions :

Utilisez b[1-9]d{0-2}b pour vérifier tous les entiers positifs compris entre 1 et 999
  • Utilisez b[1-4]d{3}b pour vérifier tous les entiers positifs compris entre 1000 et 4999
  • Utilisez b5[0-5] d{ 2}b pour vérifier tous les entiers positifs entre 5000 et 5599
  • Utilisez b56[0-6]db pour vérifier tous les entiers positifs entre 5600 et 5669
  • Utilisez b567[0-8]b pour vérifier tous les entiers positifs compris entre 5670 et 5678
  • Pour résumer, nous pouvons utiliser l'expression régulière suivante pour vérifier tous les entiers positifs compris entre 1 -5678 :

Mais est-ce vraiment le cas ? La vérification est la suivante :

^([1-9]\d{0,2})|([1-4]\d{3})|(5[0-5]\d{2})|(56[0-6]\d)|(567[0-8])$

 

Pourquoi cela se produit-il ? ? ? La vérification des trois nombres suivants n’est pas l’effet souhaité ! ! En effet, l'expression régulière correspondra de gauche à droite lors de la correspondance, parmi eux, 2602 et 4999 peuvent être mis en correspondance en utilisant [1-9]d{0,2}, il n'est donc pas nécessaire de continuer.

Essayons d'inverser l'ordre des expressions régulières ? Comme indiqué ci-dessous :

L'effet est le suivant :

^(567[0-8])|(56[0-6]\d)|(5[0-5]\d{2})|([1-4]\d{3})|([1-9]\d{0,2})$

Ce qui nous rend heureux cette fois, c'est que tous les nombres compris entre 1 et 5678 sont sélectionnés J'ai compris! ! Mais 5 sur 789 et -5 ont été sélectionnés. En effet, nous n'avons ajouté ^ qu'avant le premier regroupement. Ce que nous devons faire, c'est ajouter ^ avant chaque regroupement. Comme indiqué ci-dessous :

Cette fois, l'effet ne pose aucun problème, comme suit :

^(567[0-8])|^(56[0-6]\d)|^(5[0-5]\d{2})|^([1-4]\d{3})|^([1-9]\d{0,2})$

Cela se voit à partir de ceci : le principe de l'ordre combiné (entier positif) : De la combinaison de plages de la valeur maximale à la combinaison de plages de la valeur minimale.

从这个例子受到启发,我们对于指定范围内的正整数的验证的第一个例子中的每一个分组后添加$或\b也可以解决问题。

也就是说下面的两行代码均有效:

^(567[0-8])|^(56[0-6]\d)|^(5[0-5]\d{2})|^([1-4]\d{3})|^([1-9]\d{0,2})$
^([1-9]\d{0,2})$|([1-4]\d{3})$|(5[0-5]\d{2})$|(56[0-6]\d)$|(567[0-8])$

6.实数的验证

这里要介绍的实数的验证是至少包含一个小数点的实数,因此实数就包括了整数部分、小数部分和小数点。

 验证方法如下:

-?(0|([1-9]\d*))\.\d+

其中-?表示可以有负号也可以没有负号,(0|[1-9]\d*)表示整数部分可以是0也可以是不以0开头的其他整数,\.是为了对元字符.进行转义,\d+表示在小数点后面可以有1个或多个数字重复。所以它可以用来验证一般形式的实数(如0.0、1.2、-1.20等),还可以用来验证负0,如-0.0、-0.00等。

如果我们希望验证指定精度的实数,我们只需要把末尾的+修改成相应的精度即可,如下所示:

-?(0|([1-9]\d*))\.\d{3}$

即表示小数部分长度为3的实数。

7.科学计数法的验证

科学计数法就是把一个数记成a*10^n的形式。其中,a是一位整数或着是只有一位整数的小数(如5,3.2等等),所以可知1<=|a|<10。而n是一位整数。所以不难得出科学计数法的验证方法如下所示:

^-?[1-9](\.\d+)?\*10\^-?\d+$

第二部分:4种国内电话号码的验证

我们知道中国的电话号码的形式不外乎有下面四种:

1.手机号码

2.固定电话号码(不包括区号)

3.区号+固定电话号码

4.区号+固定电话号码+分机号

下面我们按照顺序逐一介绍

1.手机号码

目前国内的手机号码多是13开头、15开头和18开头,并且第三位数字目前都有【0-9】这10个数,所以验证起来就很简单了。如下所示:

     

显然第二种方法更简单一些。

 2.固定电话号码(不包括区号)

固定电话号码一般为7位(如2268358)或8位(82668110),所以验证起来是非常简单的,如下所示:

 

但是,某个地区的电话号码往往是固定在一个具体的范围里的,比如新疆石河子某个地区为2268001-2268999,这时想要确定就需要稍微花一些功夫了。

我们可以把2268001-2268999划分为2268001-2268009和2268010-2268099和2268100-2268999。这样,把验证三者的正则表达式组合起来即可。如下所示:

2268((00[1-9])|(0[1-9]\d)|([1-9]\d{2}))

 

PS 这里就不具体介绍啦,都是很简单的知识,如果有疑问可以看我的上一篇博文,它对基本知识阐述得很具体。

3.区号+固定电话号码验证

区号的长度一般为3-4位,固定电话号码的长度一般为7-8位,比如029-82668110为3位区号和8位固定电话号码的组合,0993-2268358是4位区号和7位固定号码的组合。且在区号和固定号码之间一般都是由-(连字符)链接的。可知,我们只需要对区号和固定电话分别验证即可。  

\b0\d{2,3}[- ]?\d{7,8}\b

演示效果如下:

 

4.区号+固定电话号码验证+分机号码验证

一些比较大的公司、企业或者政府部门在向外部提供固定的电话号码是,除了区号、固定电话号码之外,还可能包括分机号码。

下面我们以4位的分级号码为例。一般在分机号码之前可能是空格,也可能是-(连字符),还可能什么都没有。 于是验证方法如下:

\b0\d{2,3}[- ]?\d{7,8}[- ]?\d{4}\b

演示效果如下:

    

第三部分:2种身份证号码的验证

1.基本知识

15位身份证号码:

1985年我国实行居民身份证制度,当时签发的身份证号码是15位的。其中前6位为地址码,中间6位为出生日期码(年月日各用两位数字表示),最后三位为顺序码。

(注:顺序码是对同年、同月、同日出生的人编订序号,顺序码的奇数分配给男性,偶数分配给女性)

18位身份证号码:

1999年我国开始使用18位的身份证号。其中前6位为地址码,中间8位为出生日期码(年用4位表示,月日各用2位表示),最后四位为顺序码和校验码。

(注:年份用4位是因为使用2位会导致冲突,比如1903年和2003年出生的人。而校验码主要是为了校验计算机输入公民身份证号码的前17位数字是否正确,其取值范围是0至10,当值等于10时,用X表示)

 2. 15位身份证号码的验证

前6位地址码可以为任意数字,78位的年份码为任意数字,9和10位的月份码应当在01-12之间,11和12位的日期码在01-31之间,最后三位的顺序码为长度为3的任意字符串。于是验证方法如下:

复制代码 代码如下:


\b\d{8}(0[1-9]|1[012])(0[1-9]|[12]\d|3[01])\d{3}\b

 3. 18位身份证号码的验证

前6位地址码为任意数字,7-10位的年份码前两位以19或20开头(这里就不考虑18开头了),月日同15位的身份证号码,三位顺序码为长度为3的任意字符串,最后以为验证码为0-9或X。于是验证方法如下:

\b\d{6}(19|20)\d{2}(0[1-9]|1[012])(0[1-9]|[12]\d|3[01])\d{3}(\d|X)\b

因为只要知道了思路,正则表达式写出来并不难,所以这里就不细讲了。

 第四部分:邮政编码验证

我国邮政编码的编码规则:我国采用四级六位编码制,前两位表示省、市、自治区,第三位代表邮区,第四位代表县、市,最后两位代表投递邮局,最后两位是代表从这个城市哪个投递区投递的,即投递区的位置。例如:邮政编码“130021”“13”代表吉林省,“00”代表省会长春,“21”代表所在投递区。

因此验证我国的邮政编码就十分方便了,如下所示:

     

第五部分:两种IP地址的验证

IP地址可以简单验证,还可以精确验证。

1.简单IP地址验证

我首先ping到了http://www.jb51.net/的IP地址:42.121.252.58。 实际上IP地址一般是1~3位整数.1~3位整数.1~3位整数.1~3位整数,于是我们可以通过下面的正则表达式作简单验证:

([1-9]\d{0,2}\.){3}[1-9]\d{0,2}

验证效果如下所示:

 

2.精确IP地址验证

显然,上面的简单IP地址验证是不精确的,比如999.999.999.999这就不是一个正确的IP地址。

我们知道32位IP地址的每一个数值都是在0~255之间,所以对于1~3位整数.1~3位整数.1~3位整数.1~3位整数我们应该将整数限制在0~255之间,显然,这里要使用分区间的方法了。

0-99之间可以这样表示:([1-9]\d?)|0              (注意这里的表示方法,如果这个数不为0,那么前面就不能有0)

100-199 peut être exprimé comme ceci : 1d{2}

200-249 peut être exprimé comme ceci : 2[0-4]d

250-255 Cela signifie : 25[0-5]

Donc, pour résumer, la méthode pour obtenir la vérification précise de l'adresse IP est la suivante :

Copiez le code Le code est le suivant :


(((25[0-5])|2[0-4]d|1d{2}|[1-9]d|0).){3}(( 25[0 -5])|2[0-4]d|1d{2}|[1-9]d|0)

L'effet de démonstration est le suivant :

Il convient de noter que le regroupement est crucial Ce n'est que si vous divisez le groupe dans le bon groupe qu'il n'y aura aucun problème.

Ce qui précède représente l'intégralité du contenu de cet article. J'espère qu'il sera utile à l'étude de chacun. J'espère également que tout le monde soutiendra Script Home.

Je pense que vous maîtrisez la méthode après avoir lu le cas dans cet article. Pour des informations plus intéressantes, veuillez prêter attention aux autres articles connexes sur le site Web chinois de php !

Lecture recommandée :

Explication détaillée de l'utilisation du modificateur g de modèle de correspondance global régulier

Modificateur m d'expression régulière (Correspondance multiligne) Explication détaillée de l'utilisation

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn