【发布时间】:2021-05-17 21:15:50
【问题描述】:
每当我尝试更改列表中数据框的名称时,都会遇到错误。我认为这是由于我尝试更改的名称与数据框中的长度之间的长度不同。如果这似乎是重复的帖子,我深表歉意。如果是这种情况,我会删除,但如果有人能指出我正确的方向,我将不胜感激。
library(lubridate)
library(tidyverse)
date <- rep_len(seq(dmy("01-01-2010"), dmy("31-12-2013"), by = "days"),1000)
ID <- rep(c("A","B","C", "D", "E"), 100)
df <- data.frame(date = date,
x = runif(length(date), min = 60000, max = 80000),
y = runif(length(date), min = 800000, max = 900000),
ID)
df1 <- df %>% group_split(ID)
l <- list(1,2,3,4,5)
我已经能够使用它来尝试更改它,但尝试后出现错误:
for(i in 1: length(df1)){
names(l) <- unlist(df1[[i]]$ID)
}
Error in names(l) <- unlist(df1[[i]]$ID) :
'names' attribute [200] must be the same length as the vector [5]
【问题讨论】:
-
我不太确定你想做什么。请您进一步澄清一下吗?
unlist(df1)将变为vector。为什么要将vector分配给list的“名称”? -
不一定是这样。我想要的输出是使用
df1列表中的ID将图片中列表l中的名称分配ID值。在我的实际数据集中,ID值太多,我无法在c()函数中列出它们,所以我希望找到一种更有效的方法来做到这一点。