pandas中DataFrame使用append无效/不工作问题解决方案

一、问题介绍

场景:在使用python的pandas库进行数据处理时,对某个DataFrame进行添加行操作,使用append函数进行实现。

使用方式

data = pd.read_csv("product.csv", encoding='utf-8')
new_line = {"id":1, "name":"peach"}
data.append(new_line, ignore_index=True)

问题程序未报错但是DataFrame的值未发生改变

二、append用法

DataFrame.append(other, ignore_index=False, verify_integrity=False, sort=None)

功能说明:向dataframe对象中添加新的行,如果添加的列名不在dataframe对象中,将会被当作新的列进行添加

参数解释
other新行数据,可以是DataFrame、series、dict、list
ignore_index默认值为False,如果为True则不使用index标签
verify_integrity默认值为False,如果为True当创建相同的index时会抛出ValueError的异常
sortboolean,默认是None

三、错误原因&解决方案

原因:append函数返回一个添加了新行的对象(新DataFrame),函数的调用者(原DataFrame)不发生改变
正确用法:将操作结果赋值给目标DataFrame,data = data.append(new_line, ignore_index=True)

data = pd.read_csv("product.csv", encoding='utf-8')
new_line = {"id":1, "name":"peach"}
data = data.append(new_line, ignore_index=True)

感想:感觉有点反智,浪费了一个多小时,只想报之以呵呵
在这里插入图片描述

  • 40
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 20
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 20
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值