怎么查看csv文件的编码_python学习笔记:read_csv()——encoding(字符解码)

3731aa30854f4481790908802cef7707.png

前言

在使用pandas读取csv文件时,通常需要指定解码方式,最常用的是UTF-8。

UTF-8不解释了,国际化编码标准,html现在最标准的编码格式。

但是有时使用UTF-8还是会报错,到底是什么原因呢?


请看一个案例:

import pandas as pd
file_path=r'E:test_dataAdventureWorksDW-data-warehouse-install-scriptDimAccount.csv'
df = pd.read_csv(file_path,sep="|",encoding="utf-8",header=None,na_values='null',dtype=str)

运行后报错:

UnicodeDecodeError: 'utf-8' codec can't decode byte 0xff in position 0: invalid start byte

接下来重点来了,请注意看报错语句,它提醒你utf-8不能解码0xff 。

那么0xff 是什么呢?

首先思考一个问题:既然有这么多编码方式,那文件打开的时候,windows系统是如何判断该使用哪种编码方式呢?

答案是 windows 在文件头部增加了几个字节以表示编码方式。

  • 三个字节(0xef, 0xbb, 0xbf)表示UTF-8;
  • 两个字节(0xff, 0xfe或者0xfe, 0xff)表示UTF-16(Unicode);
  • 无表示GB**。

说明0xff需要使用UTF-16才能解码

这里提一下,LE(little-endian)和BE(big-endian)。LE和BE代表字节序,分别表示字节从低位/高位开始。 我们常接触到的CPU都是LE,所以windows里Unicode未指明字节序时默认指的是LE。此处encoding="utf-16LE" 。

# 接下来,修改解码方式为UTF-16LE:
df = pd.read_csv(file_path,sep="|",encoding="utf-16LE",header=None,na_values='null',dtype=str)  

执行成功。打印第0行验证下:

print(df.iloc[0])

还有一种更简单的方法,如果csv文件不大,可以用记事本打开,查看-状态栏,可以看到文件下方有编码方式:UTF-16LE 。

db0dd853a3eb7a9aa00b5e2e46b5b55c.png

总结

使用read_csv()时,怎么知道csv文件的编码方式呢?

方法一:不妨先试试encoding="UTF-8",如果报错,可以通过分析报错信息获取编码方式。

方法二:用记事本打开csv文件,查看状态栏,显示编码方式。

  • 15
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个简单的 Python 实例,演示如何对 CSV 文件进行读取、写入和操作: 首先,假设我们有一个 CSV 文件,名为 `example.csv`,内容如下: ``` Name, Age, City John, 25, New York Sarah, 32, Los Angeles Tom, 19, Chicago ``` 1. 读取 CSV 文件 我们可以使用 Python 的内置模块 `csv` 来读取 CSV 文件,示例代码如下: ```python import csv with open('example.csv') as csv_file: csv_reader = csv.reader(csv_file) for row in csv_reader: print(row) ``` 运行以上代码,输出如下: ``` ['Name', ' Age', ' City'] ['John', ' 25', ' New York'] ['Sarah', ' 32', ' Los Angeles'] ['Tom', ' 19', ' Chicago'] ``` 2. 写入 CSV 文件 我们可以使用 Python 的内置模块 `csv` 来写入 CSV 文件,示例代码如下: ```python import csv with open('example.csv', mode='w') as csv_file: fieldnames = ['Name', 'Age', 'City'] writer = csv.DictWriter(csv_file, fieldnames=fieldnames) writer.writeheader() writer.writerow({'Name': 'Alice', 'Age': 28, 'City': 'San Francisco'}) writer.writerow({'Name': 'Bob', 'Age': 35, 'City': 'New York'}) ``` 运行以上代码后,会在当前目录下创建一个新的 `example.csv` 文件,并写入以下内容: ``` Name,Age,City Alice,28,San Francisco Bob,35,New York ``` 3. 对 CSV 文件进行操作 我们可以使用 Python 的内置模块 `csv` 来对 CSV 文件进行操作,示例代码如下: ```python import csv with open('example.csv') as csv_file: csv_reader = csv.DictReader(csv_file) for row in csv_reader: row['Age'] = int(row['Age']) + 1 with open('example_new.csv', mode='w') as new_file: fieldnames = ['Name', 'Age', 'City'] writer = csv.DictWriter(new_file, fieldnames=fieldnames) writer.writeheader() for row in csv_reader: writer.writerow(row) ``` 运行以上代码后,会在当前目录下创建一个新的 `example_new.csv` 文件,并写入以下内容: ``` Name,Age,City John,26,New York Sarah,33,Los Angeles Tom,20,Chicago ``` 以上就是对 CSV 文件进行读取、写入和操作的 Python 实例。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值