2014-03-25 16 views
1

我有一組43個變量/列,默認命名爲X1,X2,X3 ..... X46,當我創建數據框時。我需要用Q將X重新分區。有沒有更快的方法來做到這一點,或者我必須單獨使用每個X的rename()?請幫助,我想學習完成此的有效方法! (我是新手R程序員)在R中快速命名同名的多列

回答

4
names(dataframe) <- gsub("X", "Q", names(dataframe), fixed = TRUE) 

fixed = TRUE因爲你沒有實際使用正則表達式使得它更快。

+0

哇,這實際上做到了!非常感謝!你能否添加一些關於gsub函數的信息以及regex如何使用?這可能對未來有所幫助:) –

+1

您可以在R中鍵入'?gsub'。簡要說,'gsub(search_regex,replacement_regex,string_to_make_replacements_on)'。注意它是矢量化的,所以你可以做'gsub(「X」,「Q」,c(「MAX」,「SIX」))',並且它會變成c(「MAQ」,「SIQ」)。 '。 –

+0

再一次,謝謝! –

2

假設cols是列名的向量,你可以用gsub來代替。

> cols 
## [1] "X1" "X2" "X3" "X4" "X5" "X6" "X7" "X8" "X9" "X10" "X11" "X12" "X13" "X14" 
##[15] "X15" "X16" "X17" "X18" "X19" "X20" "X21" "X22" "X23" "X24" "X25" "X26" "X27" "X28" 
##[29] "X29" "X30" "X31" "X32" "X33" "X34" "X35" "X36" "X37" "X38" "X39" "X40" "X41" "X42" 
##[43] "X43" 

> gsub("X", "Q", cols) 
## [1] "Q1" "Q2" "Q3" "Q4" "Q5" "Q6" "Q7" "Q8" "Q9" "Q10" "Q11" "Q12" "Q13" "Q14" 
##[15] "Q15" "Q16" "Q17" "Q18" "Q19" "Q20" "Q21" "Q22" "Q23" "Q24" "Q25" "Q26" "Q27" "Q28" 
##[29] "Q29" "Q30" "Q31" "Q32" "Q33" "Q34" "Q35" "Q36" "Q37" "Q38" "Q39" "Q40" "Q41" "Q42" 
##[43] "Q43" 
0

假設df是您的數據幀,例如,

> df = data.frame(matrix(0,1,43)) 

您可以先清空當前列名稱,然後用任何需要的前綴命名它們,例如, "Q",使用:

> colnames(df)=NULL 
> colnames(df)=colnames(df, do.NULL=FALSE, prefix="Q")