CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

[Python] Tornado : Retour d'une Coroutine

_Anjou
_Anjou
Niveau 9
24 septembre 2016 à 09:49:47

Bonjour, je m'essaie à Tornado ( http://www.tornadoweb.org ) et j'avais une question concernant les Coroutines.

La doc sur les Coroutines : http://www.tornadoweb.org/en/stable/guide/coroutines.html

D'après la doc, on peut effectuer plusieurs requêtes HTTP en parallèle de cette façon :

@gen.coroutine
def parallel_fetch_many(urls):
    responses = yield [http_client.fetch(url) for url in urls]
    # responses is a list of HTTPResponses in the same order

Mais pour pouvoir utiliser responses par la suite, je peux ajouter return responses ?
Sachant que j'utilise une seule fois dans mon programme un processus asynchrone, j'appelle la Coroutine de cette façon :

# run_sync() doesn't take arguments, so we must wrap the
# call in a lambda.
IOLoop.current().run_sync(lambda: parallel_fetch_many(googleLinks))

De cette façon, ça démare la IOLoop, exécute la coroutine et stop la IOLoop. C'est correct de faire de la sorte ?
Pour résumer, est-ce que le code suivant est bon ou il faut modifier quelque chose :

@gen.coroutine
def parallel_fetch_many(urls):
    responses = yield [http_client.fetch(url) for url in urls]
    return responses

googleLinks = [url1,url2,...,urln]

responses = IOLoop.current().run_sync(lambda: parallel_fetch_many(googleLinks))

do_something(responses)

Le code fonctionne mais je ne sais pas si c'est la meilleure façon de faire.

Merci

EdnaTheBeast
EdnaTheBeast
Niveau 8
25 septembre 2016 à 12:59:34

https://image.noelshack.com/fichiers/2016/38/1474488309-eco2.png

_Anjou
_Anjou
Niveau 9
26 septembre 2016 à 00:44:50

Le 25 septembre 2016 à 12:59:34 EdnaTheBeast a écrit :
https://image.noelshack.com/fichiers/2016/38/1474488309-eco2.png

? :hap:

Sinon j'ai eu une réponse sur Stack Overflow, apparemment, c'est possible de faire comme ça. Le gain de temps est très bon : 14 secondes pour 50 requêtes HTTP en parallèle contre 1-2 minutes à la chaîne.

Sous forums
  • Aide à l'achat Mac
  • Macintosh
  • Création de sites web
  • Création de Jeux
  • Linux
  • Programmation
  • Internet
  • Steam Deck
  • Hardware
La vidéo du moment