Sie können das Format erhalten Sie mit melt
und dcast
vom reshape
Paket wünschen.
Im folgenden Code habe ich die Daten in 10 Y-Gruppen und 2 X-Gruppen geschnitten, nur um die Breite der Ausgabe vernünftig zu halten. Ändern Sie 2 in 10 in der Funktion ntile
, um tatsächliche Dezile für X
zu erhalten. Ich habe auch nicht alle zusammenfassenden Artikel aufgeführt, aber der folgende Code wird Ihnen hoffentlich helfen, zusätzliche Informationen hinzuzufügen.
library(dplyr)
library(reshape2)
sm = d %>% group_by(`Y decile`=ntile(Y,10), X.decile=ntile(X,2)) %>%
summarise(`X decile` = paste0("{Count: ", n(), ", Range: ", min(X),"-",max(X),", Median: ",median(X),"}"))
sm %>% melt(id.var=c("Y decile","X.decile")) %>%
dcast(`Y decile` ~ variable + X.decile, value.var="value", fill="")
Y decile X decile_1 X decile_2
1 1 {Count: 7, Range: 0.15-0.21, Median: 0.18} {Count: 3, Range: 0.98-1, Median: 0.99}
2 2 {Count: 6, Range: 0.13-0.25, Median: 0.225} {Count: 4, Range: 0.94-0.97, Median: 0.955}
3 3 {Count: 7, Range: 0.09-0.28, Median: 0.12} {Count: 3, Range: 0.91-0.93, Median: 0.92}
4 4 {Count: 6, Range: 0.06-0.31, Median: 0.185} {Count: 4, Range: 0.87-0.9, Median: 0.885}
5 5 {Count: 8, Range: 0.02-0.35, Median: 0.185} {Count: 2, Range: 0.85-0.86, Median: 0.855}
6 6 {Count: 5, Range: 0.01-0.39, Median: 0.37} {Count: 5, Range: 0.8-0.84, Median: 0.82}
7 7 {Count: 5, Range: 0.4-0.44, Median: 0.42} {Count: 5, Range: 0.75-0.79, Median: 0.77}
8 8 {Count: 5, Range: 0.45-0.49, Median: 0.47} {Count: 5, Range: 0.7-0.74, Median: 0.72}
9 9 {Count: 1, Range: 0.5-0.5, Median: 0.5} {Count: 9, Range: 0.51-0.69, Median: 0.65}
10 10 {Count: 10, Range: 0.55-0.64, Median: 0.595}
melt
ist hier eigentlich nicht notwendig. Sie könnten zu dem folgenden, wo die zusätzliche Zeile am Ende ist, mehr erklärende Namen zu erhalten.
sm = d %>% group_by(`Y decile`=ntile(Y,10), X.decile=ntile(X,2)) %>%
summarise(`X decile` = paste0("{N: ", n(), ", Range: ", min(X),"-",max(X),", Median: ",median(X),"}")) %>%
dcast(`Y decile` ~ X.decile, value.var="X decile", fill="", value.name=) %>%
setNames(., c(names(.)[1], paste0("X decile ", names(.)[-1])))
Was haben Sie versucht? Warum hat es nicht funktioniert? – Heroka
Ich habe eine For-Loop-Lösung geschrieben und kämpfe immer noch mit der Automatisierung des Codes. Auf SO für eine schnellere Datenstrukturlösung. – Divi