正则别光想着抄,看懂用法下次你也会写
当前位置:点晴教程→知识管理交流
→『 技术文档交流 』
校验字符串是否包含大小写字母+数字+特殊字符,并且长度为8-12。如果想要使用单个正则表达式就解决上述问题,就需要稍微学习一下正则的一些高级用法了。 ^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[!@#$%^&*()_+])[a-zA-Z\d!@#$%^&*()_+]{8,12}$ 先行断言(预搜索)先行断言中不会获取任何内容,只是做一次筛查
这个正则表达式使用了正向先行断言来同时检查字符串中是否包含大小写字母、数字和特殊符号。它的含义如下:
使用这个正则表达式可以对目标字符串进行检查,判断是否满足包含大小写、数字和特殊符号,并且长度为 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地址当处理日志文件时,有时需要从日志文本中提取特定的信息。一个常见的场景是提取日志中的 IP 地址。 假设我们有一个日志文件,其中包含了多行日志记录,每行记录的格式如下: [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."); } 非捕获型分组非捕获型分组是正则表达式中的一种分组语法,用于对一组子表达式进行逻辑组合,但不会捕获匹配的结果。它以 /\b(?:\d{1,3}\.){3}\d{1,3}\b/ 解释一下这个正则表达式:
该文章在 2023/6/27 10:25:31 编辑过 |
关键字查询
相关文章
正在查询... |