Maison > développement back-end > Tutoriel Python > Pourquoi pandas DataFrame renvoie-t-il une AttributeError : l'objet 'DataFrame' n'a pas d'attribut 'append' ?

Pourquoi pandas DataFrame renvoie-t-il une AttributeError : l'objet 'DataFrame' n'a pas d'attribut 'append' ?

Barbara Streisand
Libérer: 2024-12-07 12:11:12
original
897 Les gens l'ont consulté

Why Does pandas DataFrame Throw an AttributeError: 'DataFrame' object has no attribute 'append'?

Erreur : l'objet 'DataFrame' n'a pas d'attribut 'append'

Lors de la tentative d'ajout d'un dictionnaire à un objet DataFrame, l'erreur suivante peut survenir :

AttributeError : l'objet 'DataFrame' n'a pas attribut 'append'

Malgré l'existence apparente de la méthode "append" dans DataFrame, ce problème peut être résolu en comprenant sa suppression récente.

Raison de la suppression

Dans pandas 2.0, la méthode "append" était obsolète et finalement supprimée en raison de sa nature problématique. Les utilisateurs tentaient souvent d'imiter le comportement des listes Python en employant « ajouter » dans une boucle, ce qui entraînait des inefficacités. "append" dans pandas ne modifie pas le DataFrame d'origine mais en crée un nouveau, ce qui entraîne une complexité O(n) pour les insertions répétées.

Solutions alternatives

Pour ajouter un dictionnaire à un DataFrame, deux méthodes alternatives sont recommandées :

1. Concaténation Pandas (concat)

df = pd.concat([df, pd.DataFrame([new_row])], ignore_index=True)
Copier après la connexion

Cette méthode combine le DataFrame d'origine avec la nouvelle ligne en tant que DataFrame.

2. Pandas Loc (uniquement pour RangeIndex)

df.loc[len(df)] = new_row # only use with a RangeIndex!
Copier après la connexion

Cette méthode ajoute la nouvelle ligne en la définissant au prochain index disponible dans le DataFrame. Notez que cela ne fonctionne que lorsque le DataFrame a un RangeIndex.

Ajout efficace de plusieurs lignes

Si plusieurs lignes doivent être ajoutées, envisagez l'approche suivante :

  1. Collectez les nouvelles lignes dans une liste.
  2. Créez un DataFrame à partir du list.
  3. Concaténez le nouveau DataFrame au DataFrame d'origine.

Cela garantit un ajout efficace tout en évitant la surcharge des opérations répétitives "append" ou "concat".

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!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal