我有一个包含几个元素的列表。我想将这些元素转换为单独的数据帧。但是,我不知道如何保留列名。请参见下面的代码。
for (i in 1: length(mylist)) {
assign(paste("df_",names(mylist[i]),sep = ""), as.data.frame(data.frame(mylist[i]),
col.names = names(dfi)))
}
names(df_april)
> names(df_april)
[1] "april.X" "april.Latitude" "april.month" "april.count1" "april.AOT40_1" "april.count_full"
[7] "april.AOT40_2" "april.State.Code" "april.County.Code" "april.Longitude" "april.Datum" "april.Parameter.Name"
[13] "april.State.Name" "april.County.Name" "april.year" "april.method"
正如您在上面看到的,我尝试使用带有定义的as.data.frame
的{{1}}来消除那些列名中的“ april”。但这没用。
有什么主意吗?
答案 0 :(得分:1)
在OP的代码中,将[
更改为[[
,因为第一个仍然是长度为1的list
并且具有列表名称,而第二个{{1}提取列表元素。因此,自然地,当我们执行[[
时,as.data.frame
元素名称也将在展平该元素时被附加
list
注意:最好不要在全局环境中创建多个对象。