كيفية ترتيب الخطوط في r
في كثير من الأحيان، قد ترغب في ترتيب صفوف إطار البيانات في R بترتيب معين. لحسن الحظ، من السهل القيام بذلك باستخدام وظيفة الترتيب () من مكتبة dplyr .
يشرح هذا البرنامج التعليمي عدة أمثلة للاستخدام العملي لهذه الوظيفة باستخدام إطار البيانات التالي:
#create data frame df <- data.frame(player = c('A', 'B', 'C', 'D', 'E', 'F', 'G'), points = c(12, 14, 14, 15, 20, 18, 29), assists = c(3, 5, 7, 8, 14, NA, 9)) #view data frame df player points assists 1 to 12 3 2 B 14 5 3 C 14 7 4 D 15 8 5 E 20 14 6 F 18 NA 7 G 29 9
مثال 1: تنظيم حسب عمود
يوضح الكود التالي كيفية ترتيب إطار البيانات بترتيب تصاعدي بناءً على القيم الموجودة في عمود “النقاط”:
library(dplyr) df %>% arrange(points) player points assists 1 to 12 3 2 B 14 5 3 C 14 7 4 D 15 8 5 F 18 NA 6 E 20 14 7 G 29 9
للفرز بترتيب تنازلي، يمكنك استخدام الدالة desc() :
df %>% arrange( desc (dots))
player points assists
1 G 29 9
2 E 20 14
3 F 18 NA
4 D 15 8
5 B 14 5
6 C 14 5
7 to 12 3
لاحظ أنه سيتم فرز NAs حتى النهاية سواء قمت بالفرز بترتيب تصاعدي أو تنازلي أم لا:
df %>% arrange(assists)
player points assists
1 to 12 3
2 B 14 5
3 C 14 7
4 D 15 8
5 G 29 9
6 E 20 14
7 F 18 NA
df %>% arrange( desc (assists))
player points assists
1 E 20 14
2 G 29 9
3 D 15 8
4 C 14 7
5 B 14 5
6 to 12 3
7 F 18 NA
مثال 2: الترتيب عبر أعمدة متعددة
لترتيب الصفوف عبر أعمدة متعددة، يمكننا ببساطة توفير المزيد من أسماء الأعمدة كوسيطات:
#sort by points, then assists
df %>% arrange(points, assists)
player points assists
1 to 12 3
2 B 14 5
3 C 14 7
4 D 15 8
5 F 18 NA
6 E 20 14
7 G 29 9
يمكننا أيضًا تنظيم الصفوف بعمود تصاعدي وآخر تنازلي:
#sort by points ascending, then assists descending df %>% arrange(points, desc (assists)) player points assists 1 to 12 3 2 C 14 7 3 B 14 5 4 D 15 8 5 F 18 NA 6 E 20 14 7 G 29 9
مثال 3: ترتيب الصفوف بترتيب مخصص
في بعض الأحيان قد ترغب أيضًا في فرز الصفوف بترتيب مخصص. يمكنك القيام بذلك بسهولة باستخدام عامل بمستويات محددة:
#sort by player with custom order df %>% arrange( factor (player, levels = c('D', 'C', 'A', 'B', 'E', 'F', 'G'))) player points assists 1 D 15 8 2 C 14 7 3 to 12 3 4 B 14 5 5 E 20 14 6 F 18 NA 7 G 29 9
يمكنك العثور على الوثائق الكاملة لوظيفة الترتيب () هنا .