I have a data set that has the following columns.
data.columns[1:]
Index(['Fraud (i.e. fabricated or falsified results)',
'Pressure to publish for career advancement',
'Insufficient oversight/mentoring by lab principal investigator (e.g. reviewing raw data)',
'Insufficient peer review of research',
'Selective reporting of results',
'Original findings not robust enough because not replicated enough in the lab publishing the work',
'Original findings obtained with low statistical power/poor statistical analysis',
'Mistakes or inadequate expertise in reproduction efforts',
'Raw data not available from original lab',
'Protocols, computer code or reagent information insufficient or not available from original lab',
'Methods need 'green fingers' – particular technical expertise that is difficult for others to reproduce',
'Variability of standard reagents', 'Poor experimental design',
'Bad luck'],
dtype='object')
And I want to use the columns to do the melt function, so I do the following code.
data_melt = pd.melt(data, id_vars =['respid'], value_vars =['Fraud (i.e. fabricated or falsified results)',
'Pressure to publish for career advancement',
'Insufficient oversight/mentoring by lab principal investigator (e.g. reviewing raw data)',
'Insufficient peer review of research',
'Selective reporting of results',
'Original findings not robust enough because not replicated enough in the lab publishing the work',
'Original findings obtained with low statistical power/poor statistical analysis',
'Mistakes or inadequate expertise in reproduction efforts',
'Raw data not available from original lab',
'Protocols, computer code or reagent information insufficient or not available from original lab',
"Methods need 'green fingers' – particular technical expertise that is difficult for others to reproduce",
'Variability of standard reagents',
'Poor experimental design','Bad luck'],var_name = 'factor', value_name = 'rate')
Basically, I just paste the column names into the value_vars.
My question is that is it possible to write a code to achieve the same thins?
For example, just write some code like below. (I know it is wrong.)
data_melt = pd.melt(data, id_vars =['respid'], value_vars = data.columns(), ,var_name = 'factor', value_name = 'rate')
Thanks!