आप tolist
साथ values
द्वारा numpy array
को परिवर्तित करके lists
बनाया साथ DataFrame
निर्माता का उपयोग कर सकते हैं:
import pandas as pd
d1 = {'teams': [['SF', 'NYG'],['SF', 'NYG'],['SF', 'NYG'],
['SF', 'NYG'],['SF', 'NYG'],['SF', 'NYG'],['SF', 'NYG']]}
df2 = pd.DataFrame(d1)
print (df2)
teams
0 [SF, NYG]
1 [SF, NYG]
2 [SF, NYG]
3 [SF, NYG]
4 [SF, NYG]
5 [SF, NYG]
6 [SF, NYG]
df2[['team1','team2']] = pd.DataFrame(df2.teams.values.tolist(), index= df2.index)
print (df2)
teams team1 team2
0 [SF, NYG] SF NYG
1 [SF, NYG] SF NYG
2 [SF, NYG] SF NYG
3 [SF, NYG] SF NYG
4 [SF, NYG] SF NYG
5 [SF, NYG] SF NYG
6 [SF, NYG] SF NYG
और नई DataFrame
के लिए:
df3 = pd.DataFrame(df2['teams'].values.tolist(), columns=['team1','team2'])
print (df3)
team1 team2
0 SF NYG
1 SF NYG
2 SF NYG
3 SF NYG
4 SF NYG
5 SF NYG
6 SF NYG
apply(pd.Series)
साथ समाधान बहुत धीमी है:
#7k rows
df2 = pd.concat([df2]*1000).reset_index(drop=True)
In [89]: %timeit df2['teams'].apply(pd.Series)
1 loop, best of 3: 1.15 s per loop
In [90]: %timeit pd.DataFrame(df2['teams'].values.tolist(), columns=['team1','team2'])
1000 loops, best of 3: 820 µs per loop
कॉलम नाम में "टीम 1" जैसी जगह के बारे में क्या है। मैंने कॉलम वैल्यू को इस तरह से एक्सेस करने का प्रयास किया ** डीएफ 2 ['टीम 1'] ** लेकिन यह काम नहीं करता है। – Sherlock
मुझे लगता है कि यह भी अच्छा काम करता है। – jezrael
माइनर कैविट, यदि आप इसे मौजूदा डेटाफ्रेम पर उपयोग कर रहे हैं, तो इंडेक्स रीसेट करना सुनिश्चित करें, अन्यथा यह सही तरीके से असाइन नहीं करेगा। – user1700890