Heim > Backend-Entwicklung > Python-Tutorial > Daten aus einer HTTP -API mit Python abrufen

Daten aus einer HTTP -API mit Python abrufen

Christopher Nolan
Freigeben: 2025-02-10 15:11:12
Original
748 Leute haben es durchsucht

Fetching Data from an HTTP API with Python

Python greift effizient auf die HTTP -API zu: fordert Bibliothek an und fordert Cache

an.

Dieser Artikel wird aus "praktischem Python" ausgewählt, und der Autor Stuart zeigt, wie man mit Python und mehreren Modulen von Drittanbietern leicht auf die HTTP-API zugreift.

In den meisten Fällen ist die Verarbeitung von Daten von Drittanbietern zu Zugriff auf die HTTP-API erforderlich, d. H. Das Senden von HTTP-Anfragen an Webseiten, die eher von Maschinen als manuell gelesen werden sollen. Die API-Daten befinden sich normalerweise in einem maschinenlesbaren Format, normalerweise in JSON oder XML. Lassen Sie uns mithilfe von Python sehen, wie Sie auf die HTTP -API zugreifen.

Die Grundprinzipien der Verwendung von HTTP -API sind einfach:

    Senden Sie eine HTTP -Anfrage an die URL der API, die einige Authentifizierungsinformationen (wie API -Schlüssel) enthalten kann, um zu beweisen, dass wir autorisiert sind.
  1. Daten abrufen.
  2. Verwenden Sie Daten, um nützliche Vorgänge abzuschließen.
Die Python-Standardbibliothek bietet genügend Funktionen, um all dies ohne zusätzliche Module auszuführen. Dies erleichtert jedoch unsere Arbeit, wenn wir mehrere Drittanbieter-Module verwenden, um den Prozess zu vereinfachen. Das erste ist das

-Modul. Dies ist eine HTTP-Bibliothek für Python, mit der HTTP-Daten bequemer werden als Pythons integriertes requests und können mit urllib.request installiert werden. python -m pip install requests

Um die Benutzerfreundlichkeit zu zeigen, werden wir Pixabays API (hier dokumentiert) verwenden. Pixabay ist eine Bildwebsite, auf der alle Bilder wiederverwendet werden können, was sie zu einer sehr bequemen Ressource macht. Wir werden uns auf Obstbilder konzentrieren. Bei der Manipulation der Datei werden wir später die gesammelten Fruchtbilder verwenden, aber jetzt möchten wir nur die Fruchtbilder finden.

Erstens werden wir schnell sehen, welche Bilder auf Pixabay verfügbar sind. Wir werden hundert Bilder schnappen, sie schnell stöbern und den gewünschten auswählen. Dazu benötigen wir einen Pixabay -API -Schlüssel, daher müssen wir ein Konto erstellen und dann den Schlüssel aus dem Suchbildabschnitt des API -Dokuments abrufen.

fordert Modul

an

Die grundlegenden Versionen der Verwendung des

-Moduls, um HTTP -Anforderungen an die API zu stellen, umfassen das Erstellen von HTTP -URLs, das Erstellen von Anforderungen und das Lesen von Antworten. Hier ist die Antwort im JSON -Format. Das requests -Modul macht jeden Schritt sehr einfach. Der API -Parameter ist ein Python -Wörterbuch, und die requests -Funktion macht einen Aufruf. Daher sieht ein einfacher Anruf so aus: get() requests .json Dies gibt ein Python -Objekt zurück, und wie in der API -Dokumentation vorgeschlagen, können wir seine verschiedenen Teile anzeigen:

Um hundert Ergebnisse zu erzielen, können wir einfach entscheiden, fünf Anrufe zu tätigen, von denen jedes 20 Ergebnisse erzielt, aber dies ist nicht robust genug. Ein besserer Ansatz besteht darin, die Anforderungsseite zu durchlaufen, bis Sie die gewünschten hundert Ergebnisse erzielen und dann anhalten. Dies verhindert Probleme, wenn Pixabay die Standardzahl der Ergebnisse ändert (z. B. bis 15). Es ermöglicht uns auch, die Situation zu bewältigen, in der die Suchbegriffe keine hundert Bilder haben. Wir verwenden also eine while -Schleife, die jedes Mal die Seitenzahl erhöhen. Wenn wir 100 Bilder erreicht haben oder es kein Bild zum Abrufen gibt, beenden wir die Schleife:

cache http requests

Es ist eine gute Idee, nicht mehrmals bei der HTTP -API dieselben Anfragen zu stellen. Viele APIs haben Verwendungsbeschränkungen, um Überbeanspruchung durch Anfragen zu vermeiden, und Anfragen nehmen Zeit und Mühe. Wir sollten versuchen, frühere Anfragen zu vermeiden. Glücklicherweise gibt es eine nützliche Möglichkeit, dies zu tun, wenn das Python requests -Modul verwendet wird: Installieren Sie python -m pip install requests-cache mit requests-cache. Dadurch werden die von uns getätigten HTTP -Anrufe nahtlos aufgezeichnet und die Ergebnisse speichern. Dann, später, wenn wir denselben Anruf erneut tätigen, erhalten wir das lokal gespeicherte Ergebnis, ohne wieder auf die API zugreifen zu müssen. Dies spart Zeit und Bandbreite. Um requests_cache zu verwenden, es zu importieren und ein CachedSession zu erstellen und dann session.get anstelle von requests.get zu verwenden, um die URL zu erhalten, erhalten wir die Vorteile des Caching ohne zusätzliche Anstrengung:

Ausgabe

erzeugen

Um die Abfrageergebnisse anzuzeigen, müssen wir das Bild irgendwo anzeigen. Eine bequeme Möglichkeit besteht darin, eine einfache HTML -Seite zu erstellen, um jedes Bild anzuzeigen. Pixabay bietet kleine Miniaturansichten für jedes Bild, das in der API -Antwort previewURL bezeichnet wird, sodass wir eine HTML -Seite erstellen können wollen und unterschreiben Sie den Fotografen. Daher könnte jedes Bild auf der Seite so aussehen:

Wir können es aus der Liste images mit Listenverständnis erstellen und dann "n".join() verwenden, um alle Ergebnisse in eine große Zeichenfolge zu verkettet:

Wenn wir dann eine sehr einfache HTML -Seite mit dieser Liste schreiben, können Sie sie einfach in einem Webbrowser öffnen. Zeigen Sie schnell alle Suchergebnisse an, die wir von der API erhalten Pixabay -Seite:

Fetching Data from an HTTP API with Python

Dieser Artikel ist aus praktischem Python ausgewählt und kann bei SitePoint Premium- und E-Book-Einzelhändlern gekauft werden.

(Folgende FAQs sind nach dem Originaltext umgeschrieben und optimiert)

Häufig gestellte Fragen zum Erhalten von Daten mit Pythons HTTP -API (FAQs)

  • Was ist der Unterschied zwischen http und https? http ist ein Hypertext -Transferprotokoll, und HTTPS ist ein sicheres Hypertext -Transferprotokoll. Der Hauptunterschied besteht darin, dass HTTPS SSL -Zertifikate verwendet, um eine sichere verschlüsselte Verbindung zwischen dem Server und dem Client herzustellen, während HTTP dies nicht tut. Dies macht HTTPS sicherer, wenn sensible Daten wie Kreditkarteninformationen oder Anmeldeinformationen übertragen werden.

  • Wie funktioniert HTTP in Python? Mehrere Bibliotheken können in Python verwendet werden, um HTTP -Anforderungen auszustellen. Die am häufigsten verwendeten ist requests. Mit dieser Bibliothek können Sie HTTP-Anforderungen und Prozessantworten senden, einschließlich Verarbeitung von Cookies, Formulardaten, mehrteiligen Dateien und mehr. Es ist ein leistungsstarkes Tool für die Interaktion mit Webdiensten und kann in einer Vielzahl von Anwendungen verwendet werden.

  • Was sind die üblichen HTTP -Methoden? Wie benutze ich sie in Python? Die häufigsten HTTP -Methoden sind Get, Post, Put, Löschen, Kopf, Optionen und Patch. In Python können Sie die requests Bibliothek verwenden, um diese Methoden zu verwenden. Um beispielsweise eine Get -Anfrage zu senden, können Sie requests.get(url) und um eine Postanforderung zu senden, können Sie requests.post(url, data) verwenden.

  • Wie gehe ich mit HTTP -Antworten in Python um? Wenn Sie mit der Bibliothek requests HTTP -Anforderungen in Python senden, erhalten Sie ein Antwortobjekt. Dieses Objekt enthält die Antwort des Servers auf Ihre Anfrage. Wenn sich die Antwort im JSON -Format befindet, können Sie response.text oder response.json() auf den Inhalt der Antwort zugreifen. Sie können auch response.status_code verwenden, um den Statuscode der Antwort zu überprüfen.

  • Wie verwendet ich HTTP -Header in Python? Sie können sie in Python verwenden, indem Sie HTTP -Header als Wörterbuch zum requests -Parameter der headers -Funktion übergeben. Zum Beispiel requests.get(url, headers={'User-Agent': 'my-app'}). Der Header kann verwendet werden, um zusätzliche Informationen über die Anfrage oder den Kunden bereitzustellen, z. B. Benutzeragenten, Inhaltstyp, Autorisierung usw.

  • Wie gehe ich mit Cookies in Python um? Cookies können in Python unter Verwendung des cookies -attributs des Antwortobjekts verarbeitet werden. Sie können auf die vom Server gesendeten Cookies mit response.cookies zugreifen und die Cookies an den Server senden, indem Sie sie als Wörterbuch an den Parameter requests der cookies -Funktion übergeben.

  • Wie sende ich Formulardaten mit der Postanforderung in Python? kann es mit einer Postanforderung in Python gesendet werden, indem die Formdaten als Wörterbuch an den Parameter requests.post der data -Funktion übergeben werden. Zum Beispiel requests.post(url, data={'key': 'value'}). Die requests Bibliothek codiert die Daten automatisch im richtigen Format.

  • Wie sende ich eine Datei mit der Postanforderung in Python? Dateien können mit post -Anfragen in Python gesendet werden, indem sie als Wörterbuch an den Parameter requests.post der files -Funktion übergeben werden. Das Wörterbuch sollte den Namen des Dateifelds als Schlüssel und das Tupel enthalten, das den Dateinamen und das Dateiobjekt als Werte enthält.

  • Wie kann man mit Fehlern und Ausnahmen der Bibliothek in Python umgehen? requests Die Bibliothek in Python wirft Ausnahmen für bestimmte Arten von Fehlern wie Netzwerkfehler oder Zeitüberschreitungen aus. Sie können den Versuch/außer Block verwenden, um diese Ausnahmen zu fangen und sie angemessen zu behandeln. Sie können auch den Statuscode der Antwort überprüfen, um HTTP -Fehler zu behandeln. requests

  • Wie kann man in Python eine asynchrone HTTP -Anfrage stellen? Sie können mit der Bibliothek asynchrone HTTP -Anforderungen in Python ausstellen. Mit dieser Bibliothek können Sie HTTP -Anfragen asynchron und Prozessantworten senden, wodurch die Leistung Ihrer Anwendung bei der Bearbeitung einer großen Anzahl von Anforderungen erheblich verbessern kann. aiohttp

Das obige ist der detaillierte Inhalt vonDaten aus einer HTTP -API mit Python abrufen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage