将函数应用于列表的所有元素以创建新列

问题描述

我具有以下功能:

get_ym = function(x) {
   paste0(str_replace(str_sub(deparse(substitute(x)),start= -11,end = -5),"[.]","-"),"-01")
}

应用于单个对象时,它可以正常工作,如下所示:

get_ym(device.2019.01.csv)
[1] "2019-01-01"

我想将此功能应用于本质上相同但日期不同的对象列表,例如device.2019.02.csv,device.2020.03.csv等。

当我使用lapply时,输出不是我想要的。

lapply(device_files,get_ym)
[[1]]
[1] "X[-01"

[[2]]
[1] "X[-01"

以此类推。

此外,我想使用get_ym函数在列表中的所有对象中创建新列。所以我写了

apply_ym = function(x) {
  x$month = get_ym(x)
}
apply_ym(device.2020.03.csv)

但这不适用于单个对象,更不用说应用于列表了。

我在做什么错了?

编辑

device_files是这样创建的对象的列表:

device_files = list.files(pattern = "^device.2")
device_files = strsplit(device_files,split = " ")

解决方法

您编写的代码用于未加引号的变量。

get_ym(device.2019.01.csv)
[1] "2019-01-01"

传递带引号的变量时不起作用。

get_ym('device.2019.01.csv')
[1] "019-01.-01"

使用list.files时,将输出为字符变量。因此,将您的功能更改为:

library(stringr)
get_ym = function(x) {
  paste0(str_replace(str_sub(x,start= -11,end = -5),"[.]","-"),"-01")
}

并将其用作。 :

x <- c('device.2019.02.csv','device.2020.03.csv')
sapply(x,get_ym,USE.NAMES = FALSE)
#[1] "2019-02-01" "2020-03-01"

要添加新列,可以将mgetMap结合使用:

device_files = list.files(pattern = "^device.2")
all_data <- Map(cbind,mget(device_files),filename = sapply(device_files,get_ym))

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...