我在數據幀rand_sample
中有一列是數據幀列表。我想只提取數據幀到數據幀中進行計算,然後再添加這些計算作爲新列在rand_sample
從數據幀列表中提取數據幀並執行計算
str(rand_sample[1, ]$times)
List of 1
$ :'data.frame': 13 obs. of 2 variables:
..$ white: num [1:13] 1800 1834 1875 1897 1887 ...
..$ black: num [1:13] 1800 1860 1946 2031 2114 ...
一是指數看起來是這樣的:
> rand_sample[1:10,]$times
[[1]]
white black
1 1800 1800
2 1834 1860
3 1875 1946
4 1897 2031
5 1887 2114
6 1839 2203
7 1835 2282
8 1880 2370
9 1875 2400
10 1892 2323
11 1612 2356
12 1622 2370
13 1619 2370
從本質上講,我想
for (i in 1:nrow(rand_sample)) {
current <- rand_sample[i, ]$times[[1]]
mW <- abs(diff(current$white))
mB <- abs(diff(current$black))
maxWhite <- max(mW)
minWhite <- min(mW)
maxBlack <- max(mB)
minBlack <- min(mB)
sdWhite <- sd(mW)
sdBlack <- sd(mB)
avgW <- mean(mW)
avgB <- mean(mB)
rand_sample[i, ]$maxWhite <- maxWhite
rand_sample[i, ]$minWhite <- minWhite
rand_sample[i, ]$maxBlack <- maxBlack
rand_sample[i, ]$minBlack <- minBlack
rand_sample[i, ]$sdWhite <- sdWhite
rand_sample[i, ]$sdBlack <- sdBlack
rand_sample[i, ]$avgTimeWhite <- avgW
rand_sample[i, ]$avgTimeBlack <- avgB
}
兩個問題:你可以在這個for
環表示
如何從
$timestamp
的每個列表中提取數據幀?rand_sample$times[[1]]
讓我只是第一行。我希望能夠像做
rand_samples$dataFrameTimes <- rand_sample$times[[1]]
,使得新列只是dataframes的列,而不是一個包含一個數據框的列表。
如何通過更快的機制模擬
for
循環?運行for
循環需要每行大約1秒。我有一個包含數千行的數據集,所以這是站不住腳的。
請提供可重現的實例中,例如通過使用rand_sample'的'的子集'dput' – Djork
數據是專有的。有另一種方法嗎? – Parseltongue