Angenommen, ich habe diese Eingabe:Progressive Verkettung einer Spalte von einer Gruppe
ID date_1 date_2 str
1 1 2010-07-04 2008-01-20 A
2 2 2015-07-01 2011-08-31 C
3 3 2015-03-06 2013-01-18 D
4 4 2013-01-10 2011-08-30 D
5 5 2014-06-04 2011-09-18 B
6 5 2014-06-04 2011-09-18 B
7 6 2012-11-22 2011-09-28 C
8 7 2014-06-17 2013-08-04 A
10 7 2014-06-17 2013-08-04 B
11 7 2014-06-17 2013-08-04 B
Ich mag progressiv die Werte der str
Spalte durch die variable Gruppe verketten ID
, wie in dem folgenden Ausgang zeigte:
ID date_1 date_2 str
1 1 2010-07-04 2008-01-20 A
2 2 2015-07-01 2011-08-31 C
3 3 2015-03-06 2013-01-18 D
4 4 2013-01-10 2011-08-30 D
5 5 2014-06-04 2011-09-18 B
6 5 2014-06-04 2011-09-18 B,B
7 6 2012-11-22 2011-09-28 C
8 7 2014-06-17 2013-08-04 A
10 7 2014-06-17 2013-08-04 A,B
11 7 2014-06-17 2013-08-04 A,B,B
ich versuchte, die ave()
Funktion mit diesem Code zu verwenden:
within(table, {
Emp_list <- ave(str, ID, FUN = function(x) paste(x, collapse = ","))
})
aber es gibt die folgende Ausgabe, die nicht genau das, was ich will:
ID date_1 date_2 str
1 1 2010-07-04 2008-01-20 A
2 2 2015-07-01 2011-08-31 C
3 3 2015-03-06 2013-01-18 D
4 4 2013-01-10 2011-08-30 D
5 5 2014-06-04 2011-09-18 B,B
6 5 2014-06-04 2011-09-18 B,B
7 6 2012-11-22 2011-09-28 C
8 7 2014-06-17 2013-08-04 A,B,B
10 7 2014-06-17 2013-08-04 A,B,B
11 7 2014-06-17 2013-08-04 A,B,B
Natürlich ich Schleifen vermeiden möchten, wie ich auf einer großen Datenbank arbeiten.
Ich fürchte, Sie müssen Schleife in diesem Fall verwenden, da dies ein sequenzielles Problem ist –
Liam, ich würde Ihnen empfehlen, eine Antwort auf diese Frage zu akzeptieren und dann eine neue Frage stellen, anstatt mehr hinzuzufügen dieses. –