كيفية إضافة عمود رقم إلى pandas dataframe
يمكنك استخدام بناء الجملة الأساسي التالي لإضافة عمود “العدد” إلى Pandas DataFrame:
df[' var1_count '] = df. groupby (' var1 ')[' var1 ']. transform (' count ')
يضيف بناء الجملة هذا عمودًا يسمى var1_count إلى DataFrame والذي يحتوي على عدد القيم في العمود المسمى var1 .
يوضح المثال التالي كيفية استخدام بناء الجملة هذا عمليًا.
مثال: إضافة عمود رقم في Pandas
لنفترض أن لدينا DataFrame الباندا التالية التي تحتوي على معلومات حول مختلف لاعبي كرة السلة:
import pandas as pd #createDataFrame df = pd. DataFrame ({' team ': ['A', 'A', 'A', 'B', 'B', 'B', 'B', 'B'], ' pos ': ['Gu', 'Fo', 'Fo', 'Fo', 'Gu', 'Gu', 'Fo', 'Fo'], ' points ': [18, 22, 19, 14, 14, 11, 20, 28]}) #view DataFrame print (df) team pos points 0 A Gu 18 1 A Fo 22 2 A Fo 19 3 B Fo 14 4 B Gu 14 5 B Gu 11 6 B Fo 20 7 B Fo 28
يمكننا استخدام الكود التالي لإضافة عمود يسمى team_count يحتوي على عدد كل فريق:
#add column that shows total count of each team
df[' team_count '] = df. groupby (' team ')[' team ']. transform (' count ')
#view updated DataFrame
print (df)
team pos points team_count
0 A Gu 18 3
1 A Fo 22 3
2 A Fo 19 3
3 B Fo 14 5
4 B Gu 14 5
5 B Gu 11 5
6 B Fo 20 5
7 B Fo 28 5
هناك 3 أسطر بقيمة الفريق A و 5 أسطر بقيمة الفريق B.
لذا:
- لكل صف حيث يساوي الفريق A، تكون القيمة في العمود team_count هي 3 .
- لكل صف يساوي فيه الفريق B، تكون القيمة في العمود team_count هي 5 .
يمكنك أيضًا إضافة عمود “الحساب” الذي يجمع عدة متغيرات معًا.
على سبيل المثال، يوضح التعليمة البرمجية التالية كيفية إضافة عمود “العدد” الذي يجمع الفريق ومتغيرات الوضع :
#add column that shows total count of each team and position
df[' team_pos_count '] = df. groupby ([' team ', ' pos ')[' team ']. transform (' count ')
#view updated DataFrame
print (df)
team pos points team_pos_count
0 A Gu 18 1
1 A Fo 22 2
2 A Fo 19 2
3 B Fo 14 3
4 B Gu 14 2
5 B Gu 11 2
6 B Fo 20 3
7 B Fo 28 3
ومن النتيجة يمكننا أن نرى:
- يوجد صف واحد يحتوي على A في عمود الفريق وGu في عمود نقاط البيع .
- يوجد صفين يحتويان على A في عمود الفريق وFo في عمود pos .
- هناك 3 صفوف تحتوي على B في عمود الفريق وFo في عمود pos .
- يوجد صفين يحتويان على B في عمود الفريق وGu في عمود نقطة البيع .
مصادر إضافية
تشرح البرامج التعليمية التالية كيفية تنفيذ المهام الشائعة الأخرى في الباندا:
الباندا: كيفية استخدام GroupBy وأعداد القيمة
الباندا: كيفية استخدام GroupBy مع عدد الصناديق
الباندا: كيفية حساب القيم في عمود مع الشرط