Avant de commencer, jetons un œil à quelques définitions.
Le projet Graph utilise GraphQL, une syntaxe qui décrit comment interroger les données. Cette syntaxe n'est pas liée à un type spécifique de base de données ou de moteur de stockage, mais est prise en charge par votre code et vos données existants. Commençons par examiner une structure de requête GraphQL très simple et les résultats que nous obtenons lorsque nous l'exécutons. Une fois le service GraphQL exécuté, il peut recevoir des requêtes GraphQL pour exécution. Le service vérifie l'instruction de requête pour s'assurer qu'elle associe uniquement les types et champs définis, puis exécute la fonction pour produire des résultats.
Comme vous pouvez le constater, la structure de la requête est la même que le résultat. Ceci est crucial pour GraphQL car le serveur sait exactement quels champs le client a demandés.
Nous pouvons utiliser GraphQL pour effectuer les opérations suivantes :
Rechercher des données
Passer les paramètres dans votre requête
# 🎜🎜# Utilisez des alias, etc.Le graphique
#🎜 🎜 #Pour mieux comprendre ce qu'est le projet The Graph et comment il fonctionne, visitez thegraph.com/docs. Il explique comment déployer un sous-graphe et comment interroger les données du sous-graphe. Un sous-graphe définit quelles données TheGraph indexera à partir d'Ethereum et comment elles seront stockées. Une fois le sous-graphe déployé, il peut être interrogé à l'aide de la syntaxe GraphQL.Dans ce tutoriel, nous nous concentrerons sur l'interrogation des données du sous-graphe.
1. Visitez The Graph Explorer (https://thegraph.com/explorer/) pour afficher tous les sous-graphes gérés qui existent sur la blockchain Ethereum. Les données peuvent être interrogées auprès de chacun de ces services hébergés (sous-graphiques). 2. Sélectionnez une page de sous-graphiques et faites attention à l'adresse de requête http et au Playground de la page. 3. Vous avez besoin de l'adresse de requête http dans votre code Python, qui est le point de terminaison qui contient les données de la blockchain. Ce service exécutera vos requêtes GraphQL.4. Assurez-vous d'expérimenter sur le Playground. Cette section du site Web vous permettra de créer et de tester vos requêtes GraphQL pour la blockchain Ethereum.
Sélectionnez un exemple de requêteUn exemple de requête s'affiche et peut être modifié
Appuyez sur le bouton Exécuter
#🎜 🎜# AFFICHER LES RÉSULTATSExemple 1 : interrogez Aave sur la blockchain Ethereum à l'aide de GraphQL en Python pour obtenir une liste des 10 derniers prêts flash par horodatage
import requests # pretty print is used to print the output in the console in an easy to read format from pprint import pprint # function to use requests.post to make an API call to the subgraph url def run_query(q): # endpoint where you are making the request request = requests.post('https://api.thegraph.com/subgraphs/name/aave/protocol' '', json={'query': query}) if request.status_code == 200: return request.json() else: raise Exception('Query failed. return code is {}.{}'.format(request.status_code, query)) # The Graph query - Query aave for a list of the last 10 flash loans by time stamp query = """ { flashLoans (first: 10, orderBy: timestamp, orderDirection: desc,){ id reserve { name symbol } amount timestamp } } """ result = run_query(query) # print the results print('Print Result - {}'.format(result)) print('#############') # pretty print the results to make it easier to read pprint(result)
La requête suivante est une liste de classement d'Uniswap, détaillant le montant déposé par les principaux fournisseurs de liquidité ETH par ordre décroissant. Cela peut vous aider à mieux analyser le comportement des utilisateurs, par exemple en suivant les acteurs populaires du marché et en observant la relation entre les fournisseurs de liquidité de l’ETH et d’autres jetons. Les autres champs utilisateur pouvant être interrogés incluent leur adresse, les actifs historiques achetés et vendus et le total des frais payés par cet utilisateur.
import requests # pretty print is used to print the output in the console in an easy to read format from pprint import pprint # function to use requests.post to make an API call to the subgraph url def run_query(q): # endpoint where you are making the request request = requests.post('https://api.thegraph.com/subgraphs/name/uniswap/uniswap-v2' '', json={'query': query}) if request.status_code == 200: return request.json() else: raise Exception('Query failed. return code is {}.{}'.format(request.status_code, query)) # The Graph query - Query Uniswap for a list of the top 10 pairs where the reserve is > 1000000 USD and the volume is >50000 USD query = """ { pairs(first: 10, where: {reserveUSD_gt: "1000000", volumeUSD_gt: "50000"}, orderBy: reserveUSD, orderDirection: desc) { id token0 { id symbol } token1 { id symbol } reserveUSD volumeUSD } } """ result = run_query(query) # print the results print('Print Result - {}'.format(result)) print('#############') # pretty print the results pprint(result)
Utiliser The Graph en Python pour interroger les données Ethereum est très puissant. De nombreuses données peuvent être interrogées à des fins de reporting et d’analyse.
Ce code est uniquement destiné à des fins d'apprentissage et de divertissement. Ce code n'a pas été audité, utilisez-le à vos propres risques, le contrat est expérimental et peut contenir des bugs.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!