Wie kann ich große DataFrames in Pandas effektiv verarbeiten, um Speicherfehler zu vermeiden?

Susan Sarandon
Freigeben: 2024-10-26 01:24:28
Original
281 Leute haben es durchsucht

How can I effectively handle large DataFrames in Pandas to avoid memory errors?

Pandas – Große DataFrames in Stücke schneiden

Die Arbeit mit großen DataFrames kann schwierig sein, insbesondere wenn sie durch Funktionen geleitet werden. Bei der Arbeit mit großen DataFrames können Speicherfehler auftreten, und das Aufteilen in kleinere Blöcke kann helfen, dieses Problem zu lindern.

So schneiden Sie einen DataFrame in kleinere Blöcke auf:

  1. Listenverständnis : Nutzen Sie das Listenverständnis, um eine Liste kleinerer DataFrames zu erstellen.
<code class="python">n = 200000  # chunk row size
list_df = [df[i:i+n] for i in range(0, df.shape[0], n)]</code>
Nach dem Login kopieren
  1. Numpy array_split: Nutzen Sie die array_split-Funktion von Numpy, um den DataFrame zu teilen.
<code class="python">list_df = np.array_split(df, math.ceil(len(df)/n))</code>
Nach dem Login kopieren

Um auf die Blöcke zuzugreifen, indizieren Sie einfach die Liste:

<code class="python">list_df[0]
list_df[1]
etc...</code>
Nach dem Login kopieren

Durch Aufteilen des DataFrame nach AcctName:

<code class="python">list_df = []

for n, g in df.groupby('AcctName'):
    list_df.append(g)</code>
Nach dem Login kopieren

Sobald der DataFrame geteilt ist In Stücke zerlegt, kann es durch eine Funktion geleitet und dann mit pd.concat.

wieder zu einem einzelnen DataFrame zusammengesetzt werden

Das obige ist der detaillierte Inhalt vonWie kann ich große DataFrames in Pandas effektiv verarbeiten, um Speicherfehler zu vermeiden?. 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
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!