客戶系統(tǒng)升級(jí),要求用戶密碼符合一定的規(guī)則,即:包含大小寫字母、數(shù)字、符號(hào),長(zhǎng)度不小于8,于是先用python寫了個(gè)簡(jiǎn)單的測(cè)試程序:
在寫解決方案前,列一下
python正則表達(dá)式中的特殊字符:
^ 表示匹配的字符必須在最前邊
$ 表示匹配的字符必須在最后邊
* 匹配* 前面的字符0次或n次
+ 匹配+ 前面的字符1次或n次
? 匹配?前面的字符0次或1次
. (小數(shù)點(diǎn))匹配除換行符外的所有字符
(x) 匹配x并記錄匹配的值
x|y 匹配x或者y
{n} 這里n是一個(gè)正整數(shù)。匹配前面的n個(gè)字符
{n,} 這里n是一個(gè)正整數(shù)。匹配至少n個(gè)前面的字符
{n,m} 這里n和m都是正整數(shù)。匹配至少n個(gè)、最多m個(gè)前面的字符
[xyz] 字符列表,匹配表中的任一字符,可以通過連接字符 - 指出字符范圍,如 [a-z] 表示所有小寫字符
[b] 匹配一個(gè)空格
b 匹配一個(gè)單詞的分界線,比如一個(gè)空格
B 匹配一個(gè)單詞的非分界線
re模塊匹配規(guī)則(re.match函數(shù)的第三個(gè)參數(shù)):
re.IGNORECASE 忽略文中的大小寫
re.LOCALE 處理字符集本地化
re.MULTILINE 是否支持多行匹配
re.DOTALL 匹配一些特殊標(biāo)記,例如使用.匹配/n等字符
re.VERBOSE 忽略正則表達(dá)式中的空格或者換行等字符
re.UNICODE 使用Unicode編碼
#encoding=utf-8#-------------------------------------------------------------------------------# Name: 模塊1# Purpose:## Author: Administrator## Created: 10-06-2014# Copyright: (c) Administrator 2014# Licence: <your licence>#-------------------------------------------------------------------------------import redef checklen(pwd): return len(pwd)>=8def checkContainUpper(pwd): pattern = re.compile('[A-Z]+') match = pattern.findall(pwd) if match: return True else: return Falsedef checkContainNum(pwd): pattern = re.compile('[0-9]+') match = pattern.findall(pwd) if match: return True else: return Falsedef checkContainLower(pwd): pattern = re.compile('[a-z]+') match = pattern.findall(pwd) if match: return True else: return Falsedef checkSymbol(pwd): pattern = re.compile('([^a-z0-9A-Z])+') match = pattern.findall(pwd) if match: return True else: return Falsedef checkPassword(pwd): #判斷密碼長(zhǎng)度是否合法 lenOK=checklen(pwd) #判斷是否包含大寫字母 upperOK=checkContainUpper(pwd) #判斷是否包含小寫字母 lowerOK=checkContainLower(pwd) #判斷是否包含數(shù)字 numOK=checkContainNum(pwd) #判斷是否包含符號(hào) symbolOK=checkSymbol(pwd) print(lenOK) print(upperOK) print(lowerOK) print(numOK) print(symbolOK) return (lenOK and upperOK and lowerOK and numOK and symbolOK)def main(): if checkPassword('Helloworld#123'): print('檢測(cè)通過') else: print('檢測(cè)未通過')if __name__ == '__main__': main()
平時(shí)用正則不多,不知道怎么寫一個(gè)正則滿足要求,用了比較笨的辦法,誰(shuí)知道一句正則檢驗(yàn)的請(qǐng)賜教!
我們?cè)賮砜匆粋€(gè)稍微復(fù)雜些的 檢測(cè)郵箱名及密碼驗(yàn)證
代碼:
main.py
# coding=gbk import re def ProcessMail(inputMail): isMatch = bool(re.match(r"^[a-zA-Z](([a-zA-Z0-9]*/.[a-zA-Z0-9]*)|[a-zA-Z0-9]*)[a-zA-Z]@([a-z0-9A-Z]+/.)+[a-zA-Z]{2,}$", inputMail,re.VERBOSE)); if isMatch: print ("郵箱注冊(cè)成功。"); else: print ("郵箱注冊(cè)失敗。"); return isMatch; def ProcessPassword(inputPassword): #處理正則表達(dá)式 isMatch = bool(re.match(r"[a-zA-Z0-9]{8}",inputPassword,flags=0)); #用type的三位表示數(shù)字type[0],小寫字母type[1],大寫字母type[2]是否都具備 if isMatch: type = [False,False,False] for i in range(0,8): temp = inputPassword[i] if ord(temp) >= ord('0') and ord(temp) <= ord('9'): type[0] = True; elif ord(temp) >= ord('a') and ord(temp) <= ord('z'): type[1] = True; elif ord(temp) >= ord('A') and ord(temp) <= ord('Z'): type[2] = True; for i in type: if i is False: isMatch = False; break; #處理是否有重復(fù)的字符出現(xiàn) if isMatch: for i in range(0,7): temp = inputPassword[i]; for j in range(i + 1,8): if inputPassword[j] == temp: isMatch = False; break; if isMatch: print ("密碼注冊(cè)成功。"); else: print ("密碼注冊(cè)失敗。"); return isMatch; if __name__ == '__main__': mailState = False; while mailState is False: inputMail = input("輸入郵箱: "); mailState = ProcessMail(inputMail); print ("/n"); # passwordState = False; while passwordState is False: inputPassword = input("輸入密碼: "); passwordState = ProcessPassword(inputPassword); print ("/n");
輸出:
輸入郵箱: a.a9@sina.com 郵箱注冊(cè)失敗。 輸入郵箱: 9a.aa@sina.com 郵箱注冊(cè)失敗。 輸入郵箱: a.a.a@sina.com 郵箱注冊(cè)失敗。 輸入郵箱: a9999@sina.com 郵箱注冊(cè)失敗。 輸入郵箱: a123.banana@..com 郵箱注冊(cè)失敗。 輸入郵箱: a123.banana@a..com 郵箱注冊(cè)失敗。 輸入郵箱: a123.banana@sina.c 郵箱注冊(cè)失敗。 輸入郵箱: a123.banana@sina.com 郵箱注冊(cè)失敗。 輸入郵箱: a123.banana@sina.com 郵箱注冊(cè)成功。
密碼的測(cè)試也滿足需求,不一一列舉