Add characters to a numeric column in dataframe

爱⌒轻易说出口 提交于 2019-12-04 00:29:40

The regex pattern "^" (outside any character-class brackets) represents the point just before the first character of a "character"-class item (aka "string" in other computer languages). This just replaces the beginning of each "character" element in vector with a stem of "chr". It implicitly coerces a "numeric" input value to "character" so alters the mode of the result.

> dat$V1 <- sub("^", "chr", dat$V1 )
> dat
    V1      V2      V3
1 chr1 3423086 3423685
2 chr1 3467184 3467723
3 chr1 4115236 4115672
4 chr1 5202437 5203057
5 chr2 7132558 7133089
6 chr2 7448688 7449283

Could, of course, have used paste("chr", dat$V1, sep=""), but I thought a regex solution might be neater.

sprintf is a lot more powerful than plain concatenation.

dat$V1 <- sprintf('chr%i', dat$V1)

We can also use interaction:

df$V1 <- interaction( "chr", df$V1, sep = "")
df

Or using sqldf:

library(sqldf)    
df$V1 <- as.character(df$V1)
df$V1 <- sqldf("select 'chr'|| V1 as V1 from df") 
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!