切片Datafram时发生KeyError

2024-04-28 08:44:04 发布

您现在位置:Python中文网/ 问答频道 /正文

我的代码看起来像:

d = pd.read_csv('Collector Output.csv')
df = pd.DataFrame(data=d)
dfa = df.copy()
dfa =  dfa.rename(columns={'OBJECTID': 'Object ID', 'test_no': 'TEST #', 'retest_no': 'RETEST #',
                        'tester': 'TESTED BY', 'date': 'DATE', 'proj_no': 'Project Number',
                        'test_elev': 'TEST ELEVATION', 'curve_no': 'CURVE #', 'curve':
                        'Curve Description', 'dry': 'Dry Maximum Density (pcf)', 'opt': 'OPT. M.C.',
                        'Material Type': 'Material Type', 'AC Thickness': 'AC Thickness', 'AB Thickness': 'AB Thickness',
                        'Wet In-place Density, pcf)': 'Wet In-place Density (pcf)', 'inplace_mo': 'FIELD M.C.',
                        'comp_dryde': 'DRY DENSITY', 'relative_c': 'R.C.', 'addl_notes': 'NOTES',
                        'material_t': 'Material Type', 'wet_inpac': 'Wet In-place', 'comp_dryde': 'comp_dryde', 'relative_c': 'relative compaction',
                        'GlobalID': 'GlobalID', 'GlobalID_2': 'GlobalID 2', 'x': 'EAST', 'y': 'NORTH'})


writer = pd.ExcelWriter('Test Test.xlsx', engine= 'xlsxwriter')
dfa.to_excel(writer, sheet_name='Output')
writer.save()

#Slice the dataframe to get the desired columns by their 'name'
dfb = dfa[['TEST #', 'DATE', 'TESTED BY', 'NORTH', 'EAST', 'TEST ELEVATION', 'CURVE #', 'OPT. M.C.', 'FIELD M.C.', 
          'DRY DENSITY', 'R.C.', 'RETEST #', 'NOTES']] 

当我运行它时,我得到一个键错误,它读作['DRY DENSITY''R.C.]而不是index。我验证了.csv中列的名称是否正确。为什么这两个专栏会给出一个问题?在


Tags: csvnointesttypeplacedensitypd
1条回答
网友
1楼 · 发布于 2024-04-28 08:44:04

我想需要两个[[]]

cols = ['TEST #', 'DATE', 'TESTED BY', 'NORTH', 'EAST', 'TEST ELEVATION', 'CURVE #', 'OPT. M.C.', 'FIELD M.C.', 'DRY DENSITY', 'R.C.', 'RETEST #', 'NOTES']
dfb = dfa[cols]

如果某些列出现错误,请添加^{}

^{pr2}$

相关问题 更多 >