Я пытался отправить запрос с помощью Python, чтобы очистить некоторые данные json с сайта. У меня нет опыта работы с GraphQL, но я думаю, что этот сайт построен на нем. Так или иначе, проблема в том, что даже если я запрашиваю его с помощью метода POST, он продолжает возвращать мне GRAPHQL_PARSE_FAILED (я опубликую результат ниже). Я предполагаю, что это потому, что в моем запросе есть «стрелка вниз с углом влево». Поскольку в сообщении говорится, что он не может проанализировать '\ u21B5'.
Вот код.
self.API_URL = 'https://pcmap-api.place.naver.com/graphql'
def get_location_info(self, query, start):
header = {
'authority': 'pcmap-api.place.naver.com',
'user-agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.121 Safari/537.36'
}
query = """
{
"query getRestaurants($input: RestaurantsInput, $isNmap: Boolean!, $isBounds: Boolean!) {↵ restaurants(input: $input) {↵ total↵ items {↵ ...RestaurantItemFields↵ easyOrder {↵ easyOrderId↵ easyOrderCid↵ businessHours {↵ weekday {↵ start↵ end↵ __typename↵ }↵ weekend {↵ start↵ end↵ __typename↵ }↵ __typename↵ }↵ __typename↵ }↵ baemin {↵ businessHours {↵ deliveryTime {↵ start↵ end↵ __typename↵ }↵ closeDate {↵ start↵ end↵ __typename↵ }↵ temporaryCloseDate {↵ start↵ end↵ __typename↵ }↵ __typename↵ }↵ __typename↵ }↵ yogiyo {↵ businessHours {↵ actualDeliveryTime {↵ start↵ end↵ __typename↵ }↵ bizHours {↵ start↵ end↵ __typename↵ }↵ __typename↵ }↵ __typename↵ }↵ __typename↵ }↵ nlu {↵ ...NluFields↵ __typename↵ }↵ brand {↵ name↵ isBrand↵ type↵ menus {↵ order↵ id↵ images {↵ url↵ desc↵ __typename↵ }↵ name↵ desc↵ price↵ isRepresentative↵ detailUrl↵ orderType↵ catalogId↵ source↵ menuId↵ nutrients↵ allergies↵ __typename↵ }↵ __typename↵ }↵ optionsForMap @include(if: $isBounds) {↵ maxZoom↵ minZoom↵ includeMyLocation↵ maxIncludePoiCount↵ center↵ spotId↵ __typename↵ }↵ __typename↵ }↵}↵↵fragment RestaurantItemFields on RestaurantSummary {↵ id↵ dbType↵ name↵ businessCategory↵ category↵ description↵ hasBooking↵ hasNPay↵ x↵ y↵ distance↵ imageUrl↵ imageUrls↵ imageCount↵ phone↵ virtualPhone↵ routeUrl↵ streetPanorama {↵ id↵ pan↵ tilt↵ lat↵ lon↵ __typename↵ }↵ roadAddress↵ address↵ commonAddress↵ blogCafeReviewCount↵ bookingReviewCount↵ totalReviewCount↵ bookingReviewScore↵ bookingUrl↵ bookingBusinessId↵ talktalkUrl↵ options↵ promotionTitle↵ agencyId↵ businessHours↵ microReview↵ tags↵ priceCategory↵ broadcastInfo {↵ program↵ date↵ menu↵ __typename↵ }↵ michelinGuide {↵ year↵ star↵ comment↵ url↵ hasGrade↵ isBib↵ alternateText↵ __typename↵ }↵ broadcasts {↵ program↵ menu↵ episode↵ broadcast_date↵ __typename↵ }↵ tvcastId↵ naverBookingCategory↵ saveCount↵ uniqueBroadcasts↵ isDelivery↵ markerLabel @include(if: $isNmap) {↵ text↵ style↵ __typename↵ }↵ imageMarker @include(if: $isNmap) {↵ marker↵ markerSelected↵ __typename↵ }↵ isTableOrder↵ isPreOrder↵ isTakeOut↵ bookingDisplayName↵ bookingVisitId↵ bookingPickupId↵ popularMenuImages {↵ name↵ price↵ bookingCount↵ menuUrl↵ menuListUrl↵ imageUrl↵ isPopular↵ usePanoramaImage↵ __typename↵ }↵ visitorReviewCount↵ visitorReviewScore↵ detailCid {↵ c0↵ c1↵ c2↵ c3↵ __typename↵ }↵ streetPanorama {↵ id↵ pan↵ tilt↵ lat↵ lon↵ __typename↵ }↵ __typename↵}↵↵fragment NluFields on Nlu {↵ queryType↵ user {↵ gender↵ __typename↵ }↵ queryResult {↵ ptn0↵ ptn1↵ region↵ spot↵ tradeName↵ service↵ selectedRegion {↵ name↵ index↵ x↵ y↵ __typename↵ }↵ selectedRegionIndex↵ otherRegions {↵ name↵ index↵ __typename↵ }↵ property↵ keyword↵ queryType↵ nluQuery↵ businessType↵ cid↵ branch↵ franchise↵ titleKeyword↵ location {↵ x↵ y↵ default↵ longitude↵ latitude↵ dong↵ si↵ __typename↵ }↵ noRegionQuery↵ priority↵ showLocationBarFlag↵ themeId↵ filterBooking↵ repRegion↵ repSpot↵ dbQuery {↵ isDefault↵ name↵ type↵ getType↵ useFilter↵ hasComponents↵ __typename↵ }↵ type↵ category↵ __typename↵ }↵ __typename↵}↵"
}
"""
data = {
'operationName': "getRestaurants",
'query': query,
'variables': {'input': {
'deviceType': "pcmap",
'display': "50",
'isNmap': "false",
'query': query,
'start': start
},
'isBound': 'true',
'isNmap': 'false'
}
}
r = requests.post(self.API_URL, headers=header, json=data).json()
Как вы можете видеть в запросе, у него есть стрелка, которую GraphQL не может проанализировать. Я предполагаю, что мне нужно преобразовать запрос в какой-то вид, понятный GraphQL. Но это немного расстраивает, так как я просто скопировал и вставил то, что только что показало Request Payload. Я поместил запрос вне параметра данных, потому что он казался слишком запутанным.
Вот результат.
{
"errors": [
{
"extensions": {
"code": "GRAPHQL_PARSE_FAILED"
},
"locations": [
{
"column": 89,
"line": 1
}
],
"message": "Syntax Error: Cannot parse the unexpected character \"\\u21B5\".",
"status": 500
}
]
}
Я действительно был бы признателен, если бы вы придумали способ решить эту проблему. Спасибо!