تحويل 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