تحويل pandas dataframe إلى numpy array (مع أمثلة)


يمكنك استخدام بناء الجملة التالي لتحويل Pandas DataFrame إلى مصفوفة NumPy:

 df. to_numpy ()

توضح الأمثلة التالية كيفية استخدام بناء الجملة هذا عمليًا.

مثال 1: تحويل DataFrame بنفس أنواع البيانات

يوضح التعليمة البرمجية التالية كيفية تحويل pandas DataFrame إلى صفيف NumPy عندما يكون كل عمود في DataFrame من نفس نوع البيانات:

 import pandas as pd

#create data frame
df1 = pd. DataFrame ({' rebounds ': [7, 7, 8, 13, 7, 4],
                    ' points ': [5, 7, 7, 9, 12, 9],
                    ' assists ': [11, 8, 10, 6, 6, 5]})

#view data frame
print (df1)

   rebound points assists
0 7 5 11
1 7 7 8
2 8 7 10
3 13 9 6
4 7 12 6
5 4 9 5

#convert DataFrame to NumPy array
new = df1. to_numpy ()

#view NumPy array
print (new)

[[ 7 5 11]
 [7 7 8]
 [8 7 10]
 [13 9 6]
 [7 12 6]
 [4 9 5]]

#confirm that new is a NumPy array
print (type(new))

<class 'numpy.ndarray'> 

#view data type
print (new. dtype )

int64

تحتوي مجموعة Numpy على نوع بيانات int64 نظرًا لأن كل عمود في الباندا DataFrame الأصلي كان int.

مثال 2: تحويل DataFrame بأنواع بيانات مختلطة

يوضح التعليمة البرمجية التالية كيفية تحويل pandas DataFrame إلى صفيف NumPy عندما لا تكون الأعمدة الموجودة في DataFrame كلها من نفس نوع البيانات:

 import pandas as pd

#create data frame
df2 = pd. DataFrame ({' player ': ['A', 'B', 'C', 'D', 'E', 'F'],
                    ' points ': [5, 7, 7, 9, 12, 9],
                    ' assists ': [11, 8, 10, 6, 6, 5]})

#view data frame
print (df2)

  player points assists
0 to 5 11
1 B 7 8
2 C 7 10
3 D 9 6
4 E 12 6
5 F 9 5

#convert DataFrame to NumPy array
new = df2. to_numpy ()

#view NumPy array
print (new)

[['A' 5 11]
 ['B' 7 8]
 ['C' 7 10]
 ['D' 9 6]
 ['E' 12 6]
 ['F' 9 5]]

#confirm that new is a NumPy array
print (type(new))

<class 'numpy.ndarray'> 

#view data type
print (new. dtype )

object

تحتوي مجموعة Numpy على نوع بيانات كائن لأنه لم تكن كافة الأعمدة الموجودة في الباندا DataFrame الأصلية من نفس نوع البيانات.

مثال 3: تحويل DataFrame وتعيين قيم NA

يوضح الكود التالي كيفية تحويل pandas DataFrame إلى مصفوفة NumPy وتحديد القيم المراد تعيينها لجميع قيم NA في DataFrame الأصلي:

 import pandas as pd

#create data frame
df3 = pd. DataFrame ({' player ': ['A', 'B', pd. NA , 'D', 'E', 'F'],
                    ' points ': [5, 7, pd. NA , 9, pd. NA , 9],
                    ' assists ': [11, 8, 10, 6, 6, 5]})

#view data frame
print (df3)

  player points assists
0 to 5 11
1 B 7 8
2 <NA> <NA> 10
3 D 9 6
4 E <NA> 6
5 F 9 5

#convert DataFrame to NumPy array
new = df3. to_numpy (na_value=' none ')

#view NumPy array
print (new)

[['A' 5 11]
 ['B' 7 8]
 ['none' 'none' 10]
 ['D' 9 6]
 ['E' 'none' 6]
 ['F' 9 5]]

#confirm that new is a NumPy array
print (type(new))

<class 'numpy.ndarray'> 

#view data type
print (new. dtype )

object

مصادر إضافية

كيفية إنشاء Pandas DataFrame من مصفوفة NumPy
كيفية تحويل قائمة إلى DataFrame في Pandas
كيفية تحويل DataFrame إلى قائمة في Pandas

Add a Comment

ایمئیل یایینلانمایاجاق ایسته‎نیله‎ن بوشلوقلار خاللانمیشدیر *