首页 > 解决方案 > 我的 sum 函数不会对某些列的值求和

问题描述

所以我有一个数据框,其中有一些包含计算值或输入值的列:

Data = {'name':  ['a', 'b'],
        'number1': [5, 3],
        'number2': [3, 2]
        }
df = pd.DataFrame(Data, columns = ['name','number1', 'number2'])

然后我像这样写我的总函数(暂时不要把名字加起来):

df.loc['Grand Total']=df.sum()

如果我在添加行之后计算更多列Grand total,它们也会得到它们的Grand total值:

df['number3'] = df['number2'] * 2

但是,当我想在某个 excel 文件中添加从表中解析的任何列时,问题就来了:

excelFile = pd.ExcelFile("my_excel_file.xlsx")
nrows = excelFile.book.sheet_by_index(2).nrows
values_from_Excel= excelFile.parse(2, skiprows=1, skipfooter= nrows-(8)).dropna(axis=1, how='all')
values_from_Excel = pd.DataFrame(
    {'name': values_from_Excel.iloc[:, 1].tolist(),
     'number4': values_from_Excel.iloc[:, 11].tolist()
    })

df = pd.merge(df, values_from_Excel, on='name', how='left')

将此列合并到 df 后,不计算值...这里有什么问题.. Grand totalnumber4

标签: pythonexcelpandasdataframe

解决方案


在所有代码之后再次分配它(带axis=1):

...
df.loc['Grand Total']=df.sum(axis=1)

推荐阅读