Копировать текст с форматированием из запроса картографического сервера ArcGIS в текстовый файл, сохраняя форматирование с использованием Python 3? - PullRequest
0 голосов
/ 25 сентября 2018

Я пытаюсь автоматизировать процесс, с помощью которого я могу запросить картографический сервер ArcGIS, взять полученный текст и сохранить его как файл .json.

Картографический сервер может быть запрошен через API.

api = "https://csg.esri-southafrica.com/server/rest/services/CSGSearch/MapServer/2/query?where=1%3D1&text=&objectIds=&time=&geometry=2053965%2C-4019103%2C2054056%2C-4019169+&geometryType=esriGeometryEnvelope&inSR=3857&spatialRel=esriSpatialRelIntersects&relationParam=&outFields=*&returnGeometry=true&returnTrueCurves=false&maxAllowableOffset=&geometryPrecision=&outSR=3857&returnIdsOnly=false&returnCountOnly=false&orderByFields=&groupByFieldsForStatistics=&outStatistics=&returnZ=false&returnM=false&gdbVersion=&returnDistinctValues=false&resultOffset=&resultRecordCount=&queryByDistance=&returnExtentsOnly=false&datumTransformation=&parameterValues=&rangeValues=&f=pjson"

Этот URL-адрес не так важен, но когда я запускаю его в браузере, он дает следующий ответ:

    {
     "displayFieldName": "SP_NAME",
     "fieldAliases": {
      "OBJECTID": "OBJECTID",
      "GID": "Geometry Identifier",
      "PRCL_KEY": "26 Digit Code",
      "PRCL_TYPE": "Parcel Type",
      "LSTATUS": "Legal Status",
      "WSTATUS": "Work Status",
      "GEOM_AREA": "Geometry Area",
      "COMMENTS": "Comments",
      "TAG_X": "Longitude",

    etc.etc.etc

Если я копирую этот текст в блокнот и сохраняю как «any_file.json»».Затем я могу загрузить это в QGIS и сохранить как шейп-файл.

Я использовал следующий код, чтобы попытаться достичь этого

import requests


mainapi = "https://csg.esri-southafrica.com/server/rest/services/CSGSearch/MapServer/2/query?where=1%3D1&text=&objectIds=&time=&geometry=2053965%2C-4019103%2C2054056%2C-4019169+&geometryType=esriGeometryEnvelope&inSR=3857&spatialRel=esriSpatialRelIntersects&relationParam=&outFields=*&returnGeometry=true&returnTrueCurves=false&maxAllowableOffset=&geometryPrecision=&outSR=3857&returnIdsOnly=false&returnCountOnly=false&orderByFields=&groupByFieldsForStatistics=&outStatistics=&returnZ=false&returnM=false&gdbVersion=&returnDistinctValues=false&resultOffset=&resultRecordCount=&queryByDistance=&returnExtentsOnly=false&datumTransformation=&parameterValues=&rangeValues=&f=pjson"

r = str(requests.get(mainapi).json())

#Write response to json text file
with open("csg_erven.json", "w") as f:
    f.write(r)

Результаты в файле .json не

они выглядят так:

{'displayFieldName': 'SP_NAME', 'fieldAliases': {'OBJECTID': 'OBJECTID', 'GID': 'Geometry Identifier', 'PRCL_KEY':

Я новичок в кодировании в целом, но я предполагаю, что форматирование здесь имеет решающее значение.Как я могу скопировать текст с форматированием?Это проблема кодирования?

Когда я вручную копирую форматированный текст из браузера, он работает нормально, но однострочный текст не работает.

Любая помощь будет принята с благодарностью.

1 Ответ

0 голосов
/ 25 сентября 2018

Мне кажется, что в сохранении файла есть некоторая путаница.Попробуйте использовать библиотеку json вместо преобразования в строку и сохранения в виде текста, что может привести к проблемам

import json
with open('csg_erven.json', 'w') as f:
    json.dump(requests.get(mainapi).json(), f)
...