python读取文件之前判断文件编码格式

困扰

经常用pandas读取csv格式文件,pandas默认使用utf-8编码格式,但有的文件并非这种编码,虽然可以通过记事本打开文件,然后另存为,通过保存格式为utf-8格式,但是这种方式实在是太麻烦太傻,如图1
手动查看编码格式。
图1
另存为其它格式
在这里插入图片描述

自动判断类型

通过代码自动判断类型,写一个get_encoding函数

def get_encoding(file):
    with open(file,'rb') as f:
        tmp = chardet.detect(f.read())
        return tmp['encoding']

正常运行需要导入chardet包

import chardet

代码中chardet.detect输入文件内容,返回要给字典,通过字典键‘encoding’获取编码值,如果文件很大,建议输入为f.read(2)就行,读入前5行内容作为输入即可

效果

if __name__ == '__main__':
    fpath = "D:\\异常检测\\nab\\realAWSCloudwatch\\realAWSCloudwatch"
    fname = "\\ec2_cpu_utilization_825cc2.csv"
    fullPath = fpath + fname
    encoding = get_encoding(fullPath)
    print(encoding)
    data = pd.read_csv(fullPath, encoding = encoding)
    print(data.head(2))

结果
在这里插入图片描述
类型为ascii
好处为每次读取文件时不用取一个一个查看文件编码格式了,自动获取编码格式并读取文件了。

 data = pd.read_csv(fullPath, encoding = encoding)

完整demo

def get_encoding(file):
    with open(file,'rb') as f:
        return chardet.detect(f.read(1))['encoding']

if __name__ == '__main__':
    fpath = "D:\\异常检测\\nab\\realAWSCloudwatch\\realAWSCloudwatch"
    fname = "\\ec2_cpu_utilization_825cc2.csv"
    fullPath = fpath + fname
    encoding = get_encoding(fullPath)
    print(encoding)
    data = pd.read_csv(fullPath, encoding = encoding)
    print(data.head(2))
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值