Maison >développement back-end >Tutoriel Python >Comment puis-je créer une nouvelle colonne dans Pandas basée sur les valeurs d'une colonne existante ?

Comment puis-je créer une nouvelle colonne dans Pandas basée sur les valeurs d'une colonne existante ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-12-27 21:14:14732parcourir

How Can I Create a New Column in Pandas Based on Values from an Existing Column?

Créer une nouvelle colonne avec des valeurs sélectionnées dans une colonne existante

Sélectionner des valeurs particulières dans une colonne existante pour remplir une nouvelle colonne est une tâche courante de manipulation de données. Explorons deux approches pour y parvenir en Python à l'aide de Pandas.

Méthode 1 : np.where for Two Choices

Lorsqu'il n'y a que deux options parmi lesquelles choisir , la fonction np.where est un choix pratique. Dans l'exemple fourni, nous souhaitons créer une colonne de couleur avec « vert » pour les valeurs de la colonne Définir égales à « Z » et « rouge » sinon.

df['color'] = np.where(df['Set']=='Z', 'green', 'red')

Méthode 2 : np .select for Multiple Choices

Pour les scénarios avec plus de deux choix, np.select offre une plus grande flexibilité. Introduisons plus de conditions pour la colonne de couleur :

  • 'jaune' pour quand (df['Set'] == 'Z') & (df['Type'] == 'A')
  • 'bleu' pour quand (df['Set'] == 'Z') & (df['Type'] == 'B')
  • 'violet' pour quand (df['Type'] == 'B')
  • 'noir' pour tous les autres cas

Le code de ce scénario est le suivant :

conditions = [
    (df['Set'] == 'Z') & (df['Type'] == 'A'),
    (df['Set'] == 'Z') & (df['Type'] == 'B'),
    (df['Type'] == 'B')]
choices = ['yellow', 'blue', 'purple']
df['color'] = np.select(conditions, choices, default='black')

Cette approche permet une personnalisation facile des conditions et des valeurs à sélectionner, ce qui la rend adaptée à des cas plus complexes. scénarios.

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!

Déclaration:
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