解决numpy或者pandas读取csv文件时总是编码报错的问题?

1.pandas读取csv文件:

import pandas as pd 
DatFrame=pd.read_csv('你的csv文件',encoding='utf-8')
print(DatFrame)

2.numpy  读取csv文件:

import numpy as np
DatFrame=np.getfromtxt('你的csv文件',encoding='utf-8',delimiter=',',skip_header=True)
print(DatFrame)

然后运行会报错(还有其他编码错误,这里就不列举了)

一.改变encoding=’‘的值,比如GBK,UTF-16,gb18030等见下图

改图转自腾讯 - 知乎 (zhihu.com),这里应该能就解决很多问题

二,改变各种常用的编码都不对,这时考虑csv文件的格式属性是否正确

这个时候我们需要判断一下文件的编码格式,利用python的chardet库

import chardet
with open('你的csv文件', 'rb') as f:#该方法也适用于其他文件类型的编码判断
    result = chardet.detect(f.read())
    print(result)
encoding = result['encoding']
print(encoding)

如果这时你的结果是

 

说明你创建csv文件方式不对,创建csv文件建议按照正确的创建方式:

  1. 打开excel,点击文件-开始
  2. 新建空白工作薄,编辑数据(也可以不编辑)
  3. 另存为csv文件

这里大家在新建csv文件时不建议直接右键通过其他文件(如excel,word等文件)更改后缀名来新建csv文件,这样会导致读取时总是报错。//但是通过txt文件更改后缀名却不会报错

//其他细节可以自行搜索,不再阐述。 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值