Возврат результатов из asyncio.get_event_loop - PullRequest
0 голосов
/ 07 мая 2018

Я новичок в использовании модуля asyncio. У меня есть следующий код, который запрашивает службу для возврата идентификаторов. Как установить переменную для возврата результатов из функции 'findIntersectingFeatures'?

Кроме того, как я могу выполнить операторы печати после выполнения run_in_executor. В настоящее время они печатаются сразу после первой итерации.

import json, requests, time
import asyncio

startTime = time.clock()

out_json = "UML10kmbuffer.json"

intersections = []

def findIntersectingFeatures(coordinate):

    coordinates = '{"rings":' + str(coordinate) + '}'
    forestCoverURL = 'http://server1.ags.com/server/rest/services/Forest_Cover/MapServer/0/query'
    params = {'f': 'json', 'where': "1=1", 'outFields': '*', 'geometry': coordinates, 'geometryType': 'esriGeometryPolygon', 'returnIdsOnly': 'true'}
    r = requests.post(forestCoverURL, data = params, verify=False)
    response = json.loads(r.content)

    if response['objectIds'] != None:
        intersections.append(response['objectIds'])

    return intersections


with open(out_json, "r") as f_in:
    for line in f_in:
        json_res = json.loads(line)

coordinates = []

# Get features
feat_json = json_res["features"]
for item in feat_json:
    coordinates.append(item["geometry"]["rings"])

loop = asyncio.get_event_loop()

for coordinate in coordinates:
    loop.run_in_executor(None, findIntersectingFeatures, coordinate)


print("Intersecting Features:  " + str(intersections))

endTime = time.clock()
elapsedTime =(endTime - startTime) / 60
print("Elapsed Time: " + str(elapsedTime))

1 Ответ

0 голосов
/ 07 мая 2018

Чтобы использовать asyncio, вы должны не просто получить цикл обработки событий, вы также должны запустить его. Вы можете использовать run_until_complete, чтобы запустить сопрограмму до завершения. Поскольку вам нужно запускать много сопрограмм параллельно, вы можете использовать asyncio.gather, чтобы объединить их в одну параллельную задачу:

coroutines = []
for coordinate in coordinates:
    coroutines.append(loop.run_in_executor(
        None, findIntersectingFeatures, coordinate))

intersections = loop.run_until_complete(asyncio.gather(*coroutines))

Кроме того, как я могу выполнить операторы печати после завершения run_in_executor.

Вы можете await позвонить на run_in_executor и поставить свой print после него:

def find_features(coordinate):
    inter = await loop.run_in_executor(None, findInterestingFeatures, coordinate)
    print('found', inter)
    return inter

# in the for loop, replace coroutines.append(loop.run_in_executor(...))
# with coroutines.append(find_features(coordinate)).
...