Поэтому я стараюсь печатать только месяц, а когда использую:
regex = r'([a-z]+) \d+'
re.findall(regex, 'june 15')
И он печатает: июнь Но когда я пытаюсь сделать то же самое для такого списка:
regex = re.compile(r'([a-z]+) \d+')
l = ['june 15', 'march 10', 'july 4']
filter(regex.findall, l)
он печатает тот же список, как будто они не учли тот факт, что мне не нужен номер.
если каждый элемент - только одна дата, используйте [re.sub (regex, '\\ 1', x) для x в l]






Используйте map вместо filter, как в этом примере:
import re
a = ['june 15', 'march 10', 'july 4']
regex = re.compile(r'([a-z]+) \d+')
# Or with a list comprehension
# output = [regex.findall(k) for k in a]
output = list(map(lambda x: regex.findall(x), a))
print(output)
Вывод:
[['june'], ['march'], ['july']]
Бонус:
Чтобы сгладить список списков, вы можете:
output = [elm for k in a for elm in regex.findall(k)]
# Or:
# output = list(elm for k in map(lambda x: regex.findall(x), a) for elm in k)
print(output)
Вывод:
['june', 'march', 'july']
Или просто понимание списка: output = [regex.findall(x) for x in a]
Здорово !! Но теперь у меня есть весь месяц в списке внутри списка. Как мне с этим справиться и вместо этого поместить их в простой список?
filter сохраняет все, если bool (condition) = True, все элементы в вашем списке совпадают и, таким образом, сохраняются