我有一个对象列表输出ldapsearch
如下:
dn: cn=HPOTTER,ou=STUDENTS,ou=HOGWARTS,o=SCHOOL dn: cn=HGRANGER,ou=STUDENTS,ou=HOGWARTS,o=SCHOOL dn: cn=RWEASLEY,ou=STUDENTS,ou=HOGWARTS,o=SCHOOL dn: cn=DMALFOY,ou=STUDENTS,ou=HOGWARTS,o=SCHOOL dn: cn=SSNAPE,ou=FACULTY,ou=HOGWARTS,o=SCHOOL dn: cn=ADUMBLED,ou=FACULTY,ou=HOGWARTS,o=SCHOOL
到目前为止,我有以下正则表达式:
/\bcn=\w*,/g
返回结果如下:
cn=HPOTTER, cn=HGRANGER, cn=RWEASLEY, cn=DMALFOY, cn=SSNAPE, cn=ADUMBLED,
我需要一个返回如下结果的正则表达式:
HPOTTER HGRANGER RWEASLEY DMALFOY SSNAPE ADUMBLED
我需要在正则表达式中进行哪些更改,以便cn=
结果中不包含模式(和逗号)?
编辑:我将用于进行sed
模式匹配,并将输出传递给其他命令行实用程序.
您必须执行分组.这是通过将正则表达式修改为:
/\bcn=\(\w*\),/g
然后,这会将结果填充到分组变量中.根据您的语言,如何提取此值将有所不同.(对于你用sed变量将是\ 1)
请注意,大多数正则表达式都不必转义括号(),但由于您使用的是sed,因此需要如上所示.
对于正则表达式的优秀资源,我建议:掌握正则表达式