Как извлечь долготу и широту из ссылки - PullRequest
3 голосов
/ 12 июля 2019

По следующей ссылке я пытаюсь извлечь долготу и широту.Я нашел похожие посты, но не один с тем же форматом.Я новичок в области регулярных выражений и манипуляций с текстом и буду признателен за любые рекомендации о том, как я могу сделать это с помощью Python.Вывод, который я хотел бы получить из этого примера:

latitude = 40.744221 
longitude = -73.982854

Большое спасибо заранее.

https://maps.googleapis.com/maps/api/staticmap?scale=1&center=40.744221%2C-73.982854&language=en&zoom=15&markers=scale%3A1%7Cicon%3Ahttps%3A%2F%2Fyelp-images.s3.amazonaws.com%2Fassets%2Fmap-markers%2Fannotation_32x43.png%7C40.744221%2C-73.982854&client=gme-yelp&sensor=false&size=315x150&signature=OjixVjNCwF7yLR5tsYw2fDRZ7bw

Ответы [ 3 ]

5 голосов
/ 12 июля 2019

В Python есть модуль для разбора URL в стандартной библиотеке

from urllib import parse

# Split off the query
_, query_string = parse.splitquery("https://maps.googleapis.com/maps/api/staticmap?scale=1&center=40.744221%2C-73.982854&language=en&zoom=15&markers=scale%3A1%7Cicon%3Ahttps%3A%2F%2Fyelp-images.s3.amazonaws.com%2Fassets%2Fmap-markers%2Fannotation_32x43.png%7C40.744221%2C-73.982854&client=gme-yelp&sensor=false&size=315x150&signature=OjixVjNCwF7yLR5tsYw2fDRZ7bw")

# Parse the query into a dict
query = parse.parse_qs(query_string)

# You can now access the query using a dict lookup
latlng = query["center"]

# And to get the values (selecting 0 as it is valid for a query string to contain the same key multiple times).
latitude, longitude = latlng[0].split(",")

Для этого варианта использования я бы избегал регулярных выражений. Модуль urllib является более явным, обрабатывает все аспекты кодирования URL и хорошо протестирован.

Еще один отличный сторонний модуль для работы с URL - это отличный YARL .

2 голосов
/ 12 июля 2019

Используйте простую re.search строку с упаковкой кортежей:

lattitude, longitude = re.search(r'center=(.*?)%2C(.*?)&', s).groups()

где s - ваша строка (ссылка).

Пример :

import re

s = 'https://maps.googleapis.com/maps/api/staticmap?scale=1&center=40.744221%2C-73.982854&language=en&zoom=15&markers=scale%3A1%7Cicon%3Ahttps%3A%2F%2Fyelp-images.s3.amazonaws.com%2Fassets%2Fmap-markers%2Fannotation_32x43.png%7C40.744221%2C-73.982854&client=gme-yelp&sensor=false&size=315x150&signature=OjixVjNCwF7yLR5tsYw2fDRZ7bw'

lattitude, longitude = re.search(r'center=(.*?)%2C(.*?)&', s).groups()

print(lattitude)  # 40.744221
print(longitude)  # -73.982854
1 голос
/ 12 июля 2019

Я предполагаю, что это выражение может вернуть желаемый результат:

center=(-?\d+\.\d+)%2C(-?\d+\.\d+)

Тест с re.findall

import re

regex = r"center=(-?\d+\.\d+)%2C(-?\d+\.\d+)"

test_str = "https://maps.googleapis.com/maps/api/staticmap?scale=1&center=40.744221%2C-73.982854&language=en&zoom=15&markers=scale%3A1%7Cicon%3Ahttps%3A%2F%2Fyelp-images.s3.amazonaws.com%2Fassets%2Fmap-markers%2Fannotation_32x43.png%7C40.744221%2C-73.982854&client=gme-yelp&sensor=false&size=315x150&signature=OjixVjNCwF7yLR5tsYw2fDRZ7bw"

print(re.findall(regex, test_str))

Тест с re.finditer

import re

regex = r"center=(-?\d+\.\d+)%2C(-?\d+\.\d+)"

test_str = "https://maps.googleapis.com/maps/api/staticmap?scale=1&center=40.744221%2C-73.982854&language=en&zoom=15&markers=scale%3A1%7Cicon%3Ahttps%3A%2F%2Fyelp-images.s3.amazonaws.com%2Fassets%2Fmap-markers%2Fannotation_32x43.png%7C40.744221%2C-73.982854&client=gme-yelp&sensor=false&size=315x150&signature=OjixVjNCwF7yLR5tsYw2fDRZ7bw"

matches = re.finditer(regex, test_str, re.MULTILINE)

for matchNum, match in enumerate(matches, start=1):

    print ("Match {matchNum} was found at {start}-{end}: {match}".format(matchNum = matchNum, start = match.start(), end = match.end(), match = match.group()))

    for groupNum in range(0, len(match.groups())):
        groupNum = groupNum + 1

        print ("Group {groupNum} found at {start}-{end}: {group}".format(groupNum = groupNum, start = match.start(groupNum), end = match.end(groupNum), group = match.group(groupNum)))

Выражение объяснено в верхней правой части этой демонстрации , если вы хотите изучить / упростить / изменить его, а в этой ссылке вы можете посмотреть, как оно будетесли хотите, сравнивайте с некоторыми примерами входных данных шаг за шагом.

...