登录
首页 >  文章 >  前端

要匹配非空白字符并精确结尾,可以使用正则表达式中的\S表示非空白字符,$表示字符串的结尾。示例:匹配以非空白字符结尾的字符串\S$这个正则表达式会匹配任何以非空白字符结尾的字符串。举个例子:输入:hello→不匹配(以空格结尾)输入:hello→匹配(以o结尾)输入:123→匹配(以3结尾)如果你想匹配整个字符串都由非空白字符组成(即不包含空格、换行等),可以用:^\S+$^表示开头\S+表示一个

时间:2026-01-19 18:42:49 274浏览 收藏

最近发现不少小伙伴都对文章很感兴趣,所以今天继续给大家介绍文章相关的知识,本文《如何用正则匹配非空白字符并精确结尾》主要内容涉及到等等知识点,希望能帮到你!当然如果阅读本文时存在不同想法,可以在评论中表达,但是请勿使用过激的措辞~

如何使用正则表达式匹配“非空白字符”并确保精确结尾

本文详解如何用 `\S` 匹配非空白字符,并构建严格边界正则(如 `name\s+\S+$`),避免尾随空格或多余文本,确保只匹配 `name test`、`name test-name` 等完整单词组合。

在正则表达式中,\s 表示任意空白字符(空格、制表符、换行符等),而其反义形式 \S(大写 S)则精准匹配任意非空白字符——这正是解决你问题的关键。

你原正则 /name\s+([A-Za-z0-9]+(?:-[A-Za-z0-9]+)*[A-Za-z0-9])(?!\S)/g 的意图是捕获连字符分隔的标识符,但 (?!\S) 是一个负向先行断言,它仅检查下一个字符不是非空白符(即等价于“下一个字符是空白或字符串结束”),却无法阻止后续存在空白+其他内容。例如 name test-name anytext 中,test-name 后紧跟空格,满足 (?!\S)(因空格不是 \S),导致匹配成功,但显然不符合“之后不能再有任何内容”的业务需求。

✅ 正确解法:使用 $ 锚定行尾,并配合 \S+ 确保 name 后只跟非空白字符直至结束:

/name\s+\S+$/gm
  • name → 字面量匹配
  • \s+ → 匹配一个或多个空白符(含空格、制表符)
  • \S+ → 匹配一个或多个非空白字符(自动涵盖字母、数字、短横线 -、下划线 _ 等,无需手动枚举)
  • $ → 严格锚定到行尾,确保 \S+ 后无任何字符(包括空格、字母、符号)

? 示例验证:

  • ✅ name test → 匹配
  • ✅ name test-name → 匹配
  • ✅ name test-name-2 → 匹配
  • ❌ name test(末尾空格)→ 不匹配($ 前不能有空格)
  • ❌ name test-name anytext → 不匹配(anytext 在 $ 之前,违反行尾约束)

⚠️ 注意事项:

  • 若需支持多行输入且每行独立校验,请务必添加 m(multiline)标志,使 ^ 和 $ 分别匹配每行起始/结尾;
  • 若目标字段需进一步限制字符集(如禁止下划线、仅允许字母数字和短横线),可替换 \S+ 为更精确模式,例如:
    /name\s+[A-Za-z0-9]+(?:-[A-Za-z0-9]+)*$/gm
  • 避免滥用 .* 或 .+,它们易导致过度匹配;\S+ 语义清晰、性能更优。

总结:\S 是匹配“非空白字符”的标准写法,结合 $ 锚点才能真正实现“之后不可再有任何内容”的语义。这是编写健壮解析规则的基础技巧。

今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

前往漫画官网入口并下载 ➜
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>