This is a dataframe I want to label. The labels are going to come from a column in another dataframe.
a b c
1 1 1 1
2 2 2 2
3 3 3 3
4 4 4 4
variable label
1 a label1
2 b label2
3 c label3
These are my tries with either indivudual labeling ( which is not possible since I have many columns in my actual data) , as well as a loop and papeR package( which I strongly want to avoid because it works once and does not work another time- OR I am not applying it correctly)
library(papeR)
library(Hmisc)
df <- data.frame(variable = c("a", "b", "c"),
label = c("label1", "label2", "label3"))
data <- data.frame(a = 1:4, b = 1:4, c = 1:4)
#### the classic column labeling
#### but my actual dataset has many calumns
Hmisc::label(data$a) <- df[1,2]
Hmisc::label(data$b) <- df[2,2]
Hmisc::label(data$c) <- df[3,2]
data
##### I want to somehow achieve this using Hmisc preferably
for(i in 1:ncol(data)){
Hmisc::label(data[i]) <- df[i,2]
}
data
#### papeR is acting. s I do not want to use it. once it works
#### once it does not
papeR::labels(data) <- df$label # this makes data a ldf
data <- as.data.frame(data)
data
I think you were already close to your desired solution, you only had to change
data[i]fordata[[i]]in the for-loop.