Heim > Backend-Entwicklung > Python-Tutorial > Wie lade ich mit Python 3 Dateien aus dem Internet herunter?

Wie lade ich mit Python 3 Dateien aus dem Internet herunter?

Mary-Kate Olsen
Freigeben: 2024-11-04 03:04:01
Original
1077 Leute haben es durchsucht

How to Download Files from the Web Using Python 3?

Herunterladen von Dateien aus dem Web in Python 3

Beim Extrahieren von URLs aus JAD-Dateien zum Herunterladen von JAR-Dateien tritt ein Fehler auf, da die URL als Zeichenfolge gespeichert wird Typ. Um dieses Problem zu lösen, untersuchen wir Methoden zum Herunterladen von Dateien mit Zeichenfolgen-URLs in Python 3.

Abrufen von Webseiteninhalten:

Um den Inhalt einer Webseite abzurufen Als Variable können wir urllib.request.urlopen verwenden und die Antwort lesen:

<code class="python">import urllib.request

url = 'http://example.com/'
response = urllib.request.urlopen(url)
data = response.read()      # bytes object
text = data.decode('utf-8') # str object</code>
Nach dem Login kopieren

Dateien herunterladen und speichern:

Für einfaches Herunterladen und Speichern von Dateien: urllib .request.urlretrieve ist optimal:

<code class="python">import urllib.request

# Download and save file from url to file_name
urllib.request.urlretrieve(url, file_name)</code>
Nach dem Login kopieren

Alternativ können Sie den lokalen Pfad und die Antwortheader abrufen:

<code class="python">file_name, headers = urllib.request.urlretrieve(url)</code>
Nach dem Login kopieren

Optimale Lösung mit urlopen und Shutil.copyfileobj:

Der empfohlene Ansatz besteht darin, urllib.request.urlopen zu verwenden, um ein dateiähnliches HTTP-Antwortobjekt abzurufen und es mit Shutil.copyfileobj:

<code class="python">import urllib.request
import shutil

# Download and save file from url to file_name
with urllib.request.urlopen(url) as response, open(file_name, 'wb') as out_file:
    shutil.copyfileobj(response, out_file)</code>
Nach dem Login kopieren

Alternativer Ansatz für kleine Dateien:

Für kleinere Dateien ist es möglich, den gesamten Download in einem Bytes-Objekt zu speichern und in eine Datei zu schreiben:

<code class="python">import urllib.request

# Download and save file from url to file_name
with urllib.request.urlopen(url) as response, open(file_name, 'wb') as out_file:
    data = response.read() # bytes object
    out_file.write(data)</code>
Nach dem Login kopieren

Komprimierte Daten im laufenden Betrieb extrahieren:

Sie können komprimierte Daten auch im laufenden Betrieb extrahieren, wenn der HTTP-Server den zufälligen Dateizugriff unterstützt:

Das obige ist der detaillierte Inhalt vonWie lade ich mit Python 3 Dateien aus dem Internet herunter?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
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