Здесь есть две вещи:
re.findall
возвращает захваченные тексты, если шаблон регулярного выражения содержит в нем группы захвата r'\\.'
в вашем шаблон соответствует двум последовательным символам, \
и любому символу, отличному от новой строки. См. ссылку findall
:
Если одна или несколько групп присутствуют в шаблоне, верните список групп; это будет список кортежей, если шаблон имеет более одной группы. Пустые совпадения включаются в результат, если они не касаются начала другого совпадения.
blockquote>Обратите внимание, что чтобы
re.findall
возвращали только совпадающие значения, вы обычно можете
- удаляет избыточные группы захвата (например,
(a(b)c)
->abc
)- преобразует все группы захвата в , не захватывая (то есть замените
(
на(?:
) , если отсутствуют обратные ссылки, которые относятся к значениям группы в шаблоне (см. ниже)- вместо
re.finditer
использовать[x.group() for x in re.finditer(pattern, s)]
)В вашем случае
findall
вернул все захваченные тексты, которые были пустыми, потому что вы\\
в [литерале] строкиr''
, которые пытались сопоставить литерал\
.Чтобы соответствовать номерам, вам нужно использовать
-?\d*\.?\d+
Регулярное выражение соответствует:
-?
- Дополнительный знак минус\d*
- Необязательные цифры\.?
- Дополнительный десятичный разделитель\d+
- 1 или более цифр.См. demo
Вот демон IDEONE :
import re s = r'abc123d, hello 3.1415926, this is my book' pattern = r'-?\d*\.?\d+' L = re.findall(pattern, s) print(L)
Рассмотрим псевдоэлемент, который сделает область зависания больше:
#text {
cursor: pointer;
font-size: 7em;
font-weight: 700;
text-transform: uppercase;
}
span {
display: inline-block;
transition: transform 200ms;
position: relative;
}
span:before {
content: "";
position: absolute;
top: 0;
left: 0;
right: 0;
height: 100%;
}
span:hover {
transform: translateY(-1em) rotate(10deg) scale(1.5);
}
span:hover::before {
transform:rotate(-10deg);
height: calc(100% + 0.5em);
}
<div class="container">
<div id="text">
<span>A</span>
<span>B</span>
<span>C</span>
<span>D</span>
<span>E</span>
<span>F</span>
</div>
</div>
Применение границы к элементам, зависающим для увеличения их площади, делает трюк. Если вы идете по этому маршруту, вам также нужно применить отрицательный запас при падении, чтобы сохранить элементы на месте.
#text {
cursor: pointer;
font-size: 7em;
font-weight: 700;
text-transform: uppercase;
span {
display: inline-block;
transition: transform 200ms;
&:hover {
transform: translateY(-1em) rotate(10deg) scale(1.5);
border: 0.3em solid transparent;
margin: -0.3em;
}
}
}