Здесь есть две вещи:
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)
* на самом деле оператор для разыменовывания указателя. Единственное время это означает "эй, что я - указатель", во время объявления переменной.
Foo* foo // declare foo, a pointer to a Foo object
&foo // the memory address of foo
*foo // de-reference the pointer - gives the Foo object (value)
mmattax хорошо покрыл различие между объявлением (как указатель) и разыменованием.
Однако относительно Вашей точки о:
(*myVar).myStructComponentX = 5;
для доступа к члену экземпляра структуры C (поскольку это) можно сделать то, что Вы сделали, или чаще всего Вы используете ->
нотация:
myVar->myStructComponentX = 5;
Objective C немного сбивает с толку здесь, потому что он недавно (в ObjC 2.0) представил синтаксис свойства , который является коротким путем для:
int val = [myObject someIntProperty];
и может теперь быть записан как:
int val = myObject.someIntProperty;
Это - Objective C (2.0) синтаксис для доступа к свойству, которое Вы объявили (не фактическая членская переменная), тогда как Ваш пример получал доступ к члену структуры C.
Удостоверяются, что Вы ясны на различии.
Как я сказал в , мой ответ Вашего предыдущего вопроса , @"yep"
уже является указателем, таким образом, нет никакой потребности *
прежде myString
, который является также указателем. В этом случае Вы присваиваете указатели не значения.