如何在不覆盖当前变量的情况下获取R代码?

时间:2015-02-20 17:20:12

标签: r

我试图通过使用source命令执行R代码来检索结果。由于某些变量具有相同的名称,因此执行的R文件中的变量将覆盖当前变量。如何在不覆盖当前变量的情况下检索结果?

#main.R Code
b=0
source('sub.R')
if(a>1){print(T)}else{print(F)}

#sub.R
b=1
test<-function(x){x=1}
a=test(b)

我想仅从a sub.R中检索bmain.R中的同一名称变量覆盖sub.R {{1}}。本质上,我想执行一个R文件,比如调用一个只保留返回值的方法。

1 个答案:

答案 0 :(得分:10)

如果您愿意,可以使用sys.source将内容导入特定环境。例如

b <- 0
ee <- new.env()
sys.source('sub.R', ee)
ee$a
# [1] 1     # the ee envir has the result of the sourcing
if(ee$a>1) {print(T)} else{print(F)}
# [1] FALSE
b
# [1] 0     #still zero

但是如果您希望源文件就像它们是函数一样,您应该只在源文件中包含一个函数,然后在主文件中调用该函数。不要试图在环境中传递值。例如

# sub.R  --------------
runsub<-function() {
    b=1
    test<-function(x){x=1}
    a=test(b)
    a
}

# main.R  -------------
b <- 0
source('sub.R')
a <- runsub()
if(a>1){print(T)}else{print(F)}

或者,如果您想编写辅助函数以从源环境返回特定值,则可以执行

sourceandgetvar <- function(filename, varname) {
    ee <- new.env()
    sys.source(filename, ee)
    stopifnot(varname %in% ls(envir=ee))
    ee[[varname]]
}

然后你可以将main.R改为

b <- 0
a <- sourceandgetvar("sub.R", "a")
if(a>1) {print(T)} else {print(F)}
# [1] FALSE
b
# [1] 0