Vytvořit nový sloupec s daty.tabulky, které počítají jedinečné hodnoty

0

Otázka

ID
1
1
2
3
3
3
3

Chci vytvořit další sloupec s daty tabulky, které počítají unikátní 1s, 2s, 3s, atd a shrnuje je. Konečné dat.stůl by být

ID CountID
1 2
1 2
2 1
3 4
3 4
3 4
3 4

Snažím se to ale nefunguje:

df[, CountID := uniqueN(df, by = ID)]
calculated-columns data.table r
2021-11-14 17:39:26
2

Nejlepší odpověď

0

data.tabulka

Můžete použít .N pro tento:

library(data.table)
DT[, CountID := .N, by = ID]
DT
#       ID CountID
#    <int>   <int>
# 1:     1       2
# 2:     1       2
# 3:     2       1
# 4:     3       4
# 5:     3       4
# 6:     3       4
# 7:     3       4

základna R

DT$CountID2 <- ave(rep(1L, nrow(DT)), DT$ID, FUN = length)

Údaje

DT <- setDT(structure(list(ID = c(1L, 1L, 2L, 3L, 3L, 3L, 3L), CountID = c(2L, 2L, 1L, 4L, 4L, 4L, 4L)), class = c("data.table", "data.frame"), row.names = c(NA, -7L)))
2021-11-14 19:03:33
0

Pomocí dplyr balíček

df1 = group_by(df, id) %>% count()
merge(df, df1)
   id n
1   1 3
2   1 3
3   1 3
4   2 1
5   3 4
6   3 4
7   3 4
8   3 4
9   4 2
10  4 2

Údaje

df = data.frame('id' = c( 1  , 1  , 1, 2, 3, 3, 3, 3, 4, 4))
2021-11-14 17:46:30

Můžu to dělat s daty.tabulka a := symbol?
Dani

Není dobře vyznají s data.table
Nad Pat

V jiných jazycích

Tato stránka je v jiných jazycích

Русский
..................................................................................................................
Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................