Regex 测试仪
针对文本测试正则表达式,并高亮显示所有匹配项。对于从事模式匹配、数据验证或文本处理的开发人员来说,这是必不可少的。通过可视化反馈实时调试和完善正则表达式,准确显示表达式匹配的内容。
常见问题
正则表达式是定义搜索模式的字符序列。Regex 用于查找、匹配和处理基于模式而非精确字符串的文本。对于验证电子邮件地址、从文本中提取数据、查找和替换操作以及解析日志文件等任务来说,它的功能非常强大。
在模式字段中输入 regex 模式,然后在文本区域粘贴测试文本。该工具会实时高亮显示所有匹配内容,向你展示你的模式所捕捉到的内容。如果没有高亮显示,说明模式不匹配。利用这种可视化反馈来完善你的模式,直到它完全符合你的需求。
最常见的标记有g"(全局)查找所有匹配项,而不是只查找第一个匹配项;"i"(大小写不敏感)忽略大写/小写的区别;"m"(多行)使 ^ 和 $ 匹配行的开始/结束,而不是只匹配字符串的开始/结束;"s"(dotall)使 .匹配换行符。将'gi'等标志组合起来,可实现全局大小写不敏感匹配。
对于电子邮件:尝试使用 /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/ 进行基本验证。用于 URL:/https?:\/\/(www\.)?[-a-zA-Z0-9@:%._\+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([-a-zA-Z0-9()@:%_\+.~#?&//=]*)/ works for most cases.请注意,完美的电子邮件/URL 验证极其复杂,这些模式可处理大多数常见情况。
点(.)匹配任何字符。星号 (*) 表示 "零次或多次",而加号 (+) 表示 "一次或多次"。因此,.* 可以匹配零个或多个任意字符(包括不匹配任何字符),而 .+ 则需要至少匹配一个字符。例如,"a.*b "匹配 "ab "或 "a123b",而 "a.+b "只匹配 "a123b"。
默认情况下,*、+ 和 {n,m} 等量化符是贪婪的,它们会尽可能多地匹配。在量化符后添加问号(?例如,在文本"<div>hello</div><div>world</div>"中,/<div>.*</div>/ 匹配整个字符串(贪婪),而 /<div>.*?</div>/ 则分别匹配每个标签(非贪婪)。
捕获组使用括号()提取匹配的特定部分。例如,/user-(\d+)/ 可以捕获数字用户 ID。捕获的值可以用大多数语言的匹配组访问。如果需要对量词进行分组,但又不想捕获值,可以使用 (?:...) 来表示非捕获分组。
将样本日志条目粘贴到测试字符串区域,然后创建模式来提取时间戳、IP 地址、状态代码或错误信息。可视化高亮显示精确匹配的内容,帮助你在日志分析工具(如 Logstash、Splunk 或自定义脚本)中部署之前完善模式。
Lookaheads(?=...)和 lookbehinds(?<=...)断言模式存在于前面或后面,而不将其包含在匹配中。例如,/\d+(?= dollars)/ 会匹配后跟 "美元 "的数字,但只捕捉数字。负向查找(?!...)和负向查找(?<!...)断言模式不存在。
是的!测试用于表单验证的 regex 模式,如电话号码、邮政编码、信用卡或自定义格式。可视化反馈可帮助您确保验证模式正确接受有效输入并拒绝无效输入,然后再将其应用到应用程序中。
