الباندا: كيفية حساب المتوسط المتحرك لكل مجموعة
يمكنك استخدام الصيغة الأساسية التالية لحساب المتوسط المتحرك للمجموعة للباندا:
#calculate 3-period moving average of 'values' by 'group' df. groupby (' group ')[' values ']. transform ( lambda x: x.rolling (3,1) .mean ())
يوضح المثال التالي كيفية استخدام بناء الجملة هذا عمليًا.
مثال: حساب المتوسط المتحرك حسب المجموعة في الباندا
لنفترض أن لدينا DataFrame الباندا التالي الذي يوضح إجمالي المبيعات التي أجراها متجران خلال خمس فترات مبيعات:
import pandas as pd #createDataFrame df = pd. DataFrame ({' store ': ['A', 'A', 'A', 'A', 'A', 'B', 'B', 'B', 'B', 'B'], ' period ': [1, 2, 3, 4, 5, 1, 2, 3, 4, 5], ' sales ': [7, 7, 9, 13, 14, 13, 13, 19, 20, 26]}) #view DataFrame df store period sales 0 to 1 7 1 to 2 7 2 to 3 9 3 to 4 13 4 to 5 14 5 B 1 13 6 B 2 13 7 B 3 19 8 B 4 20 9 B 5 26
يمكننا استخدام الكود التالي لحساب متوسط مبيعات متجدد لمدة 3 أيام لكل متجر:
#calculate 3-day moving average of sales by store
df[' ma '] = df. groupby (' store ')[' sales ']. transform ( lambda x: x.rolling (3,1) .mean ())
#view updated DataFrame
df
store period sales ma
0 A 1 7 7.000000
1 to 2 7 7.000000
2 A 3 9 7.666667
3 A 4 13 9.666667
4 A 5 14 12.000000
5 B 1 13 13.000000
6 B 2 13 13.000000
7 B 3 19 15.000000
8 B 4 20 17.333333
9 B 5 26 21.666667
ملحوظة : x.rolling(3, 1) تعني حساب متوسط متجدد على مدى 3 فترات ويتطلب 1 كحد أدنى لعدد الفترات.
يعرض العمود “my” متوسط المبيعات المتحرك لمدة 3 أيام لكل متجر.
لحساب متوسط متحرك مختلف، ما عليك سوى تغيير القيمة في الدالة Rolling() .
على سبيل المثال، يمكننا بدلاً من ذلك حساب المتوسط المتحرك للمبيعات لمدة يومين لكل متجر:
#calculate 2-day moving average of sales by store
df[' ma '] = df. groupby (' store ')[' sales ']. transform ( lambda x: x.rolling (2,1) .mean ())
#view updated DataFrame
df
store period sales ma
0 to 1 7 7.0
1 to 2 7 7.0
2 to 3 9 8.0
3 A 4 13 11.0
4 to 5 14 13.5
5 B 1 13 13.0
6 B 2 13 13.0
7 B 3 19 16.0
8 B 4 20 19.5
9 B 5 26 23.0
مصادر إضافية
تشرح البرامج التعليمية التالية كيفية تنفيذ العمليات الشائعة الأخرى في الباندا:
كيفية إجراء مجموع GroupBy في Pandas
كيفية حساب القيم الفريدة باستخدام GroupBy في Pandas
كيفية استخدام Groupby وPlot في Pandas