Переопределение регулярного выражения

Я хочу, чтобы регулярное выражение соответствовало любому набору цифр, с одной возможной точкой. Если после него есть еще одна точка и больше цифр, выполните совпадение с предыдущими цифрами, точкой и следующими цифрами.
пример string = 'aa323aa232.02.03.23.99aa87..0.111111.mm'
желаемые результаты = [323, 232.02, 02.03, 03.23, 23.99, 87, 0.111111]

в настоящее время используется:

 import re i = 'aa323aa232.02.03.23.99aa87..0.111111.mm' matches = re.findall(r'(?=(\d+\.{0,1}\d+))', i) print matches 

вывод:

 ['323', '23', '232.02', '32.02', '2.02', '02.03', '2.03', '03.23', '3.23', '23.99', '3.99', '99', '87', '0.111111', '111111', '11111', '1111', '111', '11'] 

One Solution collect form web for “Переопределение регулярного выражения”

Это использует утверждение lookahead для захвата, а затем другое выражение для gobbling characters, следующего за вашими правилами:

 >>> import re >>> i = 'aa323aa232.02.03.23.99aa87..0.111111.mm' >>> re.findall(r'(?=(\d+(?:\.\d+)?))\d+(?:\.\d+(?!\.?\d))?', i) 

Вывод

 ['323', '232.02', '02.03', '03.23', '23.99', '87', '0.111111'] 
  • Python - Как отделить пунктуацию от слов пробелом, оставляя только одно пространство между пунктуацией и словом?
  • Получать последовательные заглавные слова с использованием регулярного выражения
  • Компиляция регулярного выражения внутри функции, которая называется несколько раз
  • Модуль регулярного выражения Python vs re module - несоответствие шаблона
  • совпадение конечной косой черты с регулярным выражением Python
  • Как вы используете регулярное выражение в понимании списка в Python?
  • Python re.findall с groupdicts
  • Как декомпилировать регулярное выражение?
  • Python - лучший язык программирования в мире.