У меня есть строка, как
ips_string = "private_ips = {\n \"Spoke1-VM\" = \"10.61.73.2\"\n \"Spoke2-VM\" = \"10.62.76.17\"\n}\npublic_ips = {\n \"Spoke1-VM\" = \"52.58.132.6\"\n \"Spoke2-VM\" = \"52.59.211.17\"\n}"
И я хочу получить вывод в массиве примерно так
["10.61.73.2" , "10.62.76.17", '52.58.132.6','52.59.211.17']
Я пробовал регулярное выражение и т. д., но не имел никакого плодотворного результата.
Вы можете использовать регулярное выражение с шаблоном, который в основном ищет 4 цифры, соединенные десятичными знаками.
>>> import re
>>> re.findall(r'\d+\.\d+\.\d+\.\d+', ips_string)
['10.61.73.2', '10.62.76.17', '52.58.132.6', '52.59.211.17']
спасибо за ответ, но как это работает. не могли бы вы включить несколько слов объяснения?
@pie, вот вам немного информации о re и findall. re.findall() возвращает все непересекающиеся совпадения шаблона в строке в виде списка строк. Строка сканируется слева направо, и совпадения возвращаются в том порядке, в котором они были найдены. Если элементов несколько, вы получите список. В этом примере у вас есть \d+, который ищет одну или несколько цифр. Шаблон r'\d+\.\d+\.\d+\.\d+' говорит, ищите цифры точка цифра точка... (в соответствии с форматом ip). Для каждой находки он извлекает ее и добавляет в список. Этот список, наконец, доступен для вас.
Смотрите пример здесь
r'\d+\.\d+\.\d+\.\d+' будет искать цифры в формате ip (цифры точка цифра точка ....). Посмотрите docs.python.org/3/library/re.html#regular-expression-syntax и там есть описание использования d (цифр)
import re
ips_string = "private_ips = {\n \"Spoke1-VM\" = \"10.61.73.2\"\n \"Spoke2-VM\" = \"10.62.76.17\"\n}\npublic_ips = {\n \"Spoke1-VM\" = \"52.58.132.6\"\n \"Spoke2-VM\" = \"52.59.211.17\"\n}"
pat = re.compile('(?:[0-9]{1,3}\.){3}[0-9]{1,3}')
matches = re.findall(pat, ips_string)
print(matches) # -> ['10.61.73.2', '10.62.76.17', '52.58.132.6', '52.59.211.17']
Пожалуйста, внимательно ознакомьтесь с правилами сайта: stackoverflow.com/help/how-to-ask