如果我有一个示例字符串如下所示:
LEARNING-LEARNING-LEARNING-LEARNING-LEARNING-COMPANY_ORG_CHART-LEARNING-LEARNING-LEARNING-END我只想提取第一个no。其中n由no定义。中间有连字符。
So if n=5, 我只想要前5步。
输出:
LEARNING-LEARNING-LEARNING-LEARNING-LEARNING我试过这个:
s1=re.search(r'([A-za-z_].*-{0,5}[A-za-z_].*?)',s)
print(s1.group())但是它给出了整个字符串作为输出。
LEARNING-LEARNING-LEARNING-LEARNING-LEARNING-COMPANY_ORG_CHART-LEARNING-LEARNING-LEARNING-END
In [ ]:发布于 2018-11-29 05:05:56
如果这是实际的格式,那么对于所提供的示例,正则表达式可能是过度杀伤力。另一种选择是仅使用字符串方法和索引:
x='LEARNING-LEARNING-LEARNING-LEARNING-LEARNING-COMPANY_ORG_CHART-LEARNING-LEARNING-LEARNING-END'
print('-'.join(x.split('-')[:5]))
'LEARNING-LEARNING-LEARNING-LEARNING-LEARNING'发布于 2018-11-29 05:22:11
试一试:
s1 = re.search(r'^([A-za-z_]+-){0,4}[A-za-z_]+',s)
print(s1)(此示例适用于n=5)
https://stackoverflow.com/questions/53528023
复制相似问题