R/rename.R

Defines functions rowrename colrename dimrename rename

Documented in colrename dimrename rename rowrename

rename <- function(x,...,gsub=FALSE,fixed=TRUE,warn=TRUE){
    m <- match.call(expand.dots=FALSE)
    subst <- sapply(m$...,as.character)
    if(gsub){
        names.x <- names(x)
        for(i in 1:length(subst)){
            names.x <- gsub(names(subst[i]),subst[i],names.x,fixed=fixed)
        }
        names(x) <- names.x
    }
    else {
        i <- match(names(subst),names(x))
        if(any(is.na(i))) {
            if(warn) warning("unused name(s) selected")
            if(any(!is.na(i)))
                subst <- subst[!is.na(i)]
            i <- i[!is.na(i)]
        }
        if(length(i))
            names(x)[i] <- subst
    }
    return(x)
}

dimrename <- function(x,dim=1,...,gsub=FALSE,fixed=TRUE,warn=TRUE){
    m <- match.call(expand.dots=FALSE)
    subst <- sapply(m$...,as.character)
    if(0 %in% dim){
        dimnames(x) <- rename(dimnames(x),...,gsub=gsub,fixed=fixed,warn=warn)
        dim <- dim[dim!=0]
    }
    if(length(dim)){
        for(i in 1:length(subst)){
            for(j in dim){
                if(gsub)
                    dimnames(x)[[j]] <- gsub(names(subst[i]),subst[i],dimnames(x)[[j]],fixed=fixed)
                else{
                    ii <- match(names(subst[i]),dimnames(x)[[j]])
                    if(any(is.na(ii))) {
                        if(warn) warning("unused dimname(s) selected")
                        if(any(!is.na(ii)))
                            subst[i] <- subst[!is.na(ii)]
                        ii <- ii[!is.na(ii)]
                    }
                    if(length(ii))
                        dimnames(x)[[j]][ii] <- subst[i]
                }
            }
        }
    }
    return(x)
}

colrename <- function(x,...,gsub=FALSE,fixed=TRUE,warn=TRUE){
    m <- as.list(match.call())
    m[[1]] <- as.name("dimrename")
    m <- as.call(c(m[1:2],list(dim=2),m[-(1:2)]))
    eval(m,envir=parent.frame())
}

rowrename <- function(x,...,gsub=FALSE,fixed=TRUE,warn=TRUE){
    m <- as.list(match.call())
    m[[1]] <- as.name("dimrename")
    m <- as.call(c(m[1:2],list(dim=1),m[-(1:2)]))
    eval(m,envir=parent.frame())
}

Try the memisc package in your browser

Any scripts or data that you put into this service are public.

memisc documentation built on March 31, 2023, 7:29 p.m.