正則別光想著抄,看懂用法下次你也會(huì)寫
當(dāng)前位置:點(diǎn)晴教程→知識(shí)管理交流
→『 技術(shù)文檔交流 』
校驗(yàn)字符串是否包含大小寫字母+數(shù)字+特殊字符,并且長度為8-12。如果想要使用單個(gè)正則表達(dá)式就解決上述問題,就需要稍微學(xué)習(xí)一下正則的一些高級(jí)用法了。 ^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[!@#$%^&*()_+])[a-zA-Z\d!@#$%^&*()_+]{8,12}$ 先行斷言(預(yù)搜索)先行斷言中不會(huì)獲取任何內(nèi)容,只是做一次篩查
這個(gè)正則表達(dá)式使用了正向先行斷言來同時(shí)檢查字符串中是否包含大小寫字母、數(shù)字和特殊符號(hào)。它的含義如下:
使用這個(gè)正則表達(dá)式可以對(duì)目標(biāo)字符串進(jìn)行檢查,判斷是否滿足包含大小寫、數(shù)字和特殊符號(hào),并且長度為 8 到 12 位的要求。例如: let regex = /^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[!@#$%^&*()_+])[a-zA-Z\d!@#$%^&*()_+]{8,12}$/; let str = "Password123!"; let isMatch = regex.test(str); console.log(isMatch); // 輸出: true 獲取ip地址當(dāng)處理日志文件時(shí),有時(shí)需要從日志文本中提取特定的信息。一個(gè)常見的場(chǎng)景是提取日志中的 IP 地址。 假設(shè)我們有一個(gè)日志文件,其中包含了多行日志記錄,每行記錄的格式如下: [2023-06-26 10:15:25] [INFO] Access from IP: 192.168.0.1 to URL: /home 在上述示例中,我們使用 let logText = "[2023-06-26 10:15:25] [INFO] Access from IP: 192.168.0.1 to URL: /home"; let regex = /\b(?:\d{1,3}\.){3}\d{1,3}\b/; let match = logText.match(regex); if (match) { let ipAddress = match[0]; console.log(ipAddress); // 輸出: 192.168.0.1 } else { console.log("No IP address found."); } 非捕獲型分組非捕獲型分組是正則表達(dá)式中的一種分組語法,用于對(duì)一組子表達(dá)式進(jìn)行邏輯組合,但不會(huì)捕獲匹配的結(jié)果。它以 /\b(?:\d{1,3}\.){3}\d{1,3}\b/ 解釋一下這個(gè)正則表達(dá)式:
該文章在 2023/6/27 10:25:31 編輯過 |
關(guān)鍵字查詢
相關(guān)文章
正在查詢... |