当前位置: 首页 > 知识库问答 >
问题:

字符集[]内的正则表达式捕获组()

梁丘远航
2023-03-14

我只想在空格字符()后面跟一个哈希(#)时匹配空格字符。

这就是下面的(#)试图做的,这是一个捕获组。(我试图避开括号,否则括号在组集中无法正确识别)。然而,这是行不通的。

下面的正则表达式

/#[a-zA-Z\( #\)]+/g

符合以下所有条件

#CincoDeMayo #Derby party with UNLIMITED #seafood towers

而我想分别搭配#CincoDeMayo#Derby#海鲜

有没有办法在字符集[]中指定捕获组()

共有1个答案

董桐
2023-03-14

字符类旨在匹配单个字符,因此,不可能在字符类中定义字符序列。

我想你想匹配特定的连续主题标签。使用

/#[a-zA-Z]+(?: +#[a-zA-Z]+)*/g

/#[a-zA-Z]+(?:\s+#[a-zA-Z]+)*/g

请看regex演示。

细节

  • #[a-zA-Z]-a#后跟1个ASCII字母
  • (?:-启动非捕获组。。。
    • \s-1个空格
    • #[a-zA-Z]-a#后跟1个ASCII字母

 类似资料:
  • 假设我有这个虚拟URL,我需要提取植物及其颜色作为 下面的I have正在按预期捕获我需要的元素,但是当我的URL中的植物少于4株时,它无法捕获任何东西。底部有一个指向regex测试员的链接,其中有示例代码和URL,您可以使用。 如何修改这个正则表达式,使其动态工作,从而在不需要静态URL结构的情况下捕获可用内容。现在,假设我最多只能捕获4株植物(8组) https://regex101.com/

  • 我正在研究regexone.com的问题6,我不明白分组是如何与“改变”一起工作的。 这是测试字符串: 任务是捕捉快速的棕色狐狸没有额外的空白,这可以通过完成。 但是捕获了一组([27-28])为什么?结果,捕获了两组-[6-28]和([27-28])。 分组是如何工作的?除了字符类按字符匹配而更改按单词匹配(我的基本理解)之外,处理更改和字符类还有什么区别? 注:当我甚至不知道这些问题的名称时,

  • 问题内容: 我正在尝试使用Java expr在:之后捕获正确的部分,但是在以下代码中,打印的捕获组是整个字符串,怎么了? 问题答案: 子组的编号从1开始,全文为0。只需循环执行count + 1。

  • 在Python中,如何在非捕获组中捕获组?换句话说,如何重复包含捕获组的非捕获子模式? 例如,捕获导入字符串上的所有包名。例如,字符串: 导入熊猫、操作系统、系统 将返回“pandas”、“os”和“sys”。下面的模式捕获第一个包并到达第二个包: 从这里,我想重复捕获组并匹配以下字符的子模式,即。当我用一个非捕获组包围这个子模式并重复它时: 它不再捕捉里面的群体。

  • 我正在编写一个正则表达式来解析包含标记字段的行。标签出现在等号之前,内容出现在等号之后,用单引号或双引号括起来。对于大多数字段,内容都用单引号括起来。如果字段的内容包含单引号,则该字段用双引号括起来。例如: 我的正则表达式有效,除非字段用双引号括起来。 在Debuggex中测试 在Regexr中测试 对于上面示例中标记为a的字段,a=“'D08/APPL'”,a由捕获组1匹配,后面的单引号由捕获组

  • 问题内容: 我正在使用Java的正则表达式库。我想针对以下格式验证字符串: 数字的数量未知。我想确保该字符串中至少有一个数字,并且每两个数字之间用逗号分隔。我也想从字符串中获取数字。 ( 注意: 这只是一个简化的示例,string.split无法解决我的实际问题) 我写了以下正则表达式: 验证部分起作用。但是,当我尝试提取数字时,我得到了2组: regex101版本:https://regex10