Вы также можете использовать следующий код:
dataStr = 'Abc Defg Hijk Lmn'
for word in reversed(dataStr.split()):
# do something with word
ИЛИ:
dataStr = 'Abc Defg Hijk Lmn'
removeLastWord = lambda line: ' '.join([word for word in line.split()[:-1]])
dataStr = removeLastWord(dataStr)
>>> 'Abc Defg Hijk'
dataStr = removeLastWord(dataStr)
>>> 'Abc Defg'
dataStr = removeLastWord(dataStr)
>>> 'Abc'
Я прочитал ваше обновление и считаю, что решение Романа отвечает вашим потребностям.Вы можете обновить свой код следующим образом:
searchTxt = """Abc Defg Hijk Lmn
Xyz Lmn jkf gkjhg"""
data = """kggf **Abc Defg Hijk** fgff jfkjgk djkfkgf
Akggf **Abc ** fgff jfkjgk djkfkgf
Akggf **Abc Defg fgff jfkjgk djkfkgf
gjshgs gskk **Xyz Lmn jkf**
fgsgdf fkgksk **Xyz Lmn**"""
searchWords = []
for line in (line for line in searchTxt.split('\n') if line.strip()):
words = line.split()
searchWords.extend([' '.join(words[:i]) for i in xrange(len(words), 0, -1)])
searchWords = sorted(searchWords, key=len, reverse=True)# to look first for the longest string match
res = set([line for sword in searchWords for line in data.split('\n') if sword in line])
# OR
res = []
for line in data.split('\n'):
for sword in searchWords:
if sword in line:
res.append(line)
break
И если вам нужно получить полный текст:
resultText = '\n'.join(res)