删除pandas中产生的Unnamed:xx列

python在使用 pd.read_csv(xxx, sep='\t' )  读文件时,

结果df中多出了一列 Unnamed:38,本来38个字段又多了一个,变成39个字段。

看起来就很烦。

第39列Unnamed:38,这是我们不想需要的数据,产生原因是我们在生成csv文件的时候,采用的是默认参数,我们可以在生成csv时候,可以使用下面参数解决这一个问题。

to_csv()时候,设置index=False。或者加上 index=True, index_label="id"

解决方案一:

pd.read_csv(path, index_col=0)

pd.to_csv(path, index=False)

 

解决方案二: (方案一对我遇到的环境 是无效的,因此我采用了方案二)

用pandas处理数据是,产生了 Unnamed:0 列,解决方案如下:

df.loc[ : , ~df.columns.str.contains("^Unnamed")]

如果不对的话就换成

newdf = df.loc[ : , ~df.columns.str.contains('Unnamed')]

 

所测试环境为 python3.6.5  python3.7

 

 

 

 

 

  • 6
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值