如何提取 melt 函数的列名?Python

我有一个包含以下列的数据集。


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')

而且我想使用列来做融化功能,所以我做了下面的代码。


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',

基本上,我只是将列名粘贴到 value_vars 中。


我的问题是是否可以编写代码来实现相同的目标?


例如,只需编写如下代码。(我知道这是错误的。)


data_melt = pd.melt(data, id_vars =['respid'], value_vars = data.columns(), ,var_name = 'factor', value_name = 'rate')

谢谢!


UYOU
浏览 89回答 1
1回答

慕沐林林

这是一个解决方案:# Create a dummy dataframe with columns similar to yours. df = pd.DataFrame({"respid": range(5),                   "Fraud (i.e. fabricated or falsified results)": range(5,10),                    'Pressure to publish for career advancement': range(10, 15),                    'Insufficient oversight/mentoring by lab principal investigator (e.g. reviewing raw data)': range(15,20),                    'Insufficient peer review of research': range(20,25)                  })pd.melt(df, id_vars =['respid'], value_vars=set(df.columns).difference(["respid"]))结果是:    respid                                           variable  value0        0       Fraud (i.e. fabricated or falsified results)      51        1       Fraud (i.e. fabricated or falsified results)      62        2       Fraud (i.e. fabricated or falsified results)      73        3       Fraud (i.e. fabricated or falsified results)      84        4       Fraud (i.e. fabricated or falsified results)      95        0               Insufficient peer review of research     206        1               Insufficient peer review of research     217        2               Insufficient peer review of research     228        3               Insufficient peer review of research     23...
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Python