Dplyr kullanarak bir cari toplam nasıl hesaplanır
R’deki bir sütunun toplamını dplyr paketini kullanarak hesaplamak için aşağıdaki yöntemleri kullanabilirsiniz:
Yöntem 1: Bir sütunun kümülatif toplamını hesaplama
df %>% mutate(cum_sum = cumsum(var1))
Yöntem 2: Grup başına kümülatif toplamı hesaplayın
df %>% group_by(var1) %>% mutate(cum_sum = cumsum(var2))
Aşağıdaki örnekler her yöntemin pratikte nasıl kullanılacağını göstermektedir.
Örnek 1: dplyr kullanarak kümülatif toplamı hesaplama
R’de aşağıdaki veri çerçevesine sahip olduğumuzu varsayalım:
#create dataset df <- data. frame (day=c(1, 2, 3, 4, 5, 6, 7, 8), sales=c(7, 12, 10, 9, 9, 11, 18, 23)) #view dataset df day sales 1 1 7 2 2 12 3 3 10 4 4 9 5 5 9 6 6 11 7 7 18 8 8 23
“Satış” sütunundaki değerlerin kümülatif toplamını içeren yeni bir sütun oluşturmak için aşağıdaki kodu kullanabiliriz:
library (dplyr)
#calculate cumulative sum of sales
df %>% mutate(cum_sales = cumsum(sales))
day sales cum_sales
1 1 7 7
2 2 12 19
3 3 10 29
4 4 9 38
5 5 9 47
6 6 11 58
7 7 18 76
8 8 23 99
Örnek 2: dplyr kullanarak grup başına kümülatif toplamı hesaplama
R’de aşağıdaki veri çerçevesine sahip olduğumuzu varsayalım:
#create dataset
df <- data. frame (store=c('A', 'A', 'A', 'A', 'B', 'B', 'B', 'B'),
day=c(1, 2, 3, 4, 1, 2, 3, 4),
sales=c(7, 12, 10, 9, 9, 11, 18, 23))
#view dataset
df
store day sales
1 To 1 7
2 to 2 12
3 to 3 10
4 to 4 9
5 B 1 9
6 B 2 11
7 B 3 18
8 B 4 23
“Mağaza” sütununa göre gruplandırılmış “satış” sütunundaki değerlerin kümülatif toplamını içeren yeni bir sütun oluşturmak için aşağıdaki kodu kullanabiliriz:
library (dplyr)
#calculate cumulative sum of sales by store
df %>% group_by(store) %>% mutate(cum_sales = cumsum(sales))
# A tibble: 8 x 4
# Groups: store[2]
store day sales cum_sales
1 To 1 7 7
2 A 2 12 19
3 To 3 10 29
4 A 4 9 38
5 B 1 9 9
6 B 2 11 20
7 B 3 18 38
8 B 4 23 61
Ek kaynaklar
Aşağıdaki eğitimlerde R’de diğer yaygın hesaplamaların nasıl gerçekleştirileceği açıklanmaktadır:
R’de gruba göre toplam nasıl hesaplanır
R’de grup başına ortalama nasıl hesaplanır