2 votes

Changer les objets de type tableau en chaîne de caractères dans pandas

J'ai le dataframe pandas suivant :

df11 = pd.DataFrame(columns=["col1", "col2", "col3"])
df11.loc[1] = [2,["a","q","v"],["g","h","v"]]
df11.loc[2] = [21,["b","z","o"],["h"]]
df11.loc[3] = [11,["g","s","v"],["g","h","v"]]
df11.loc[4] = [2,["a","q","v"],["n","m","k","p"]]

Comment puis-je remplacer les tableaux dans col2 et col3 avec leur équivalent en chaîne de caractères ? comme ceci :

df11 = pd.DataFrame(columns=["col1", "col2", "col3"])
df11.loc[1] = [2,"a,q,v","g,h,v"]
df11.loc[2] = [21,"b,z,o","h"]
df11.loc[3] = [11,"g,s,v","g,h,v"]
df11.loc[4] = [2,"a,q,v","n,m,k,p"]

3voto

jezrael Points 290608

Utilisation str.join avec la liste des noms de colonnes dans la boucle :

cols = ['col2','col3']
for c in cols:
    df11[c] = df11[c].str.join(',')

Ou utiliser applymap :

df11[cols] = df11[cols].applymap(','.join)

Ou lister des solutions de compréhension :

L = [[','.join(y for y in x) for x in df11[c]] for c in cols]
df11[cols] = pd.DataFrame(L, columns=df11.index).T

print (df11)
  col1   col2     col3
1    2  a,q,v    g,h,v
2   21  b,z,o        h
3   11  g,s,v    g,h,v
4    2  a,q,v  n,m,k,p

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X