Если бы у меня была строка и такой список:
myString = "This is a string which has stuff in it."
myList = ["string", "things", "python"]
Есть ли способ удалить все в myString, кроме того, что указано в myList (в этом случае удаляется все, кроме слова «строка»)? Любая помощь будет оценена
print(" ".join(i for i in myString.split() if i in myList))
?
print([x for x in myList if x in myString])
?
@Rakesh Это сработало отлично, спасибо. Это намного проще, чем все то, что я пытался сделать.
@Rakesh В качестве примечания, IIRC будет быстрее, если вы передадите список в join
, чем в генератор, т. Е. Использование понимания списка будет быстрее.
@Rakesh menthod не будет работать для myString = «Это строка, в которой есть что-то». myList = ["строка", "вещи", "питон","это"]
import re
myString = "This is a string which has stuff in it."
myList = ["string", "things", "python","it"]
print(" ".join(word for word in re.sub("[^\w]", " ", myString).split() if word in myList))
myString = "This is a string which has stuff in it."
myList = ["string", "things", "python", "it"]
print([x for x in myList if x in myString])
ВЫХОД:
['string', 'it']
вам нужно сделать инверсию вашего вывода. ОП запрашивает слова из списка, а не все остальное.
Отредактировал и исправил вывод, даунвотеры? 8-)
Не мой минус, я только указал на вашу ошибку. Но здесь проголосуйте за «питоновское» решение.
mytxt = "some sentence to ignore phase and carry on"
reg = re.compile(r"(ignore phase)")
final_str = re.sub(reg,'',mytxt)
print(final_str)
Выход -
some word to and carry on
Допускаются ли частичные совпадения?