Calcular linha significa no subconjunto de colunas

Dado um quadro de dados de amostra:

C1<-c(3,2,4,4,5)
C2<-c(3,7,3,4,5)
C3<-c(5,4,3,6,3)
DF<-data.frame(ID=c("A","B","C","D","E"),C1=C1,C2=C2,C3=C3)

DF
    ID C1 C2 C3
  1  A  3  3  5
  2  B  2  7  4
  3  C  4  3  3
  4  D  4  4  6
  5  E  5  5  3

Qual é a melhor maneira de criar um segundo quadro de dados que contenha oID coluna e a média de cada linha? Algo assim:

ID  Mean
A    3.66
B    4.33
C    3.33
D    4.66
E    4.33

Algo semelhante a:

RM<-rowMeans(DF[,2:4])

Eu gostaria de manter os meios alinhados com seusIDé.

questionAnswers(4)

yourAnswerToTheQuestion