在第二次出现字符后拆分文本

我需要在第二次出现“-”字符之前拆分文本。我现在所拥有的是产生不一致的结果。我尝试了各种组合rsplit并通读并尝试了其他解决方案,但没有结果。

要拆分的示例文件名:'some-sample-filename-to-split'以data.filename. 在这种情况下,我只想'some-sample'回来。

fname, extname = os.path.splitext(data.filename)
file_label = fname.rsplit('/',1)[-1]
file_label2 = file_label.rsplit('-',maxsplit=3)
print(file_label2,'\n','---------------','\n')

已邀请:
你可以这样做:

>>> a = "some-sample-filename-to-split"
>>> "-".join(a.split("-", 2)[:2])
'some-sample'
a.split("-", 2)将字符串拆分为第二次出现的-.

a.split("-", 2)[:2]将给出列表中的前 2 个元素。然后只需加入前 2 个元素。

或者

您可以使用正则表达式: ^([\w]+-[\w]+)

>>> import re
>>> reg = r'^([\w]+-[\w]+)'
>>> re.match(reg, a).group()
'some-sample'
编辑:正如评论中所讨论的,这是您需要的:

def hyphen_split(a):
if a.count("-") == 1:
return a.split("-")[0]
return "-".join(a.split("-", 2)[:2])

>>> hyphen_split("some-sample-filename-to-split")
'some-sample'
>>> hyphen_split("some-sample")
'some'

要回复问题请先登录注册