pandas.read_csv() 报错 OSError: Initializing from file failed,报错原因分析和解决方法

环境介绍:Python版本:Python 3.6
pandas.read_csv() 报错 OSError: Initializing from file failed,一般由两种情况引起:一种是函数参数为路径而非文件名称,另一种是函数参数带有中文。

# -*- coding: utf-8 -*-
"""
Created on 2022-3-9 13:08:39
@author: sunrz
"""
import pandas as pd
df_Iris=pd.read_csv('D:\\数据源')
df_Iris=pd.read_csv('D:\\2.0 数据源\\20220303CS607Pkey10000ID.csv')

 


以上这两种情况报错信息都是一样:

Traceback (most recent call last):
(报错细节不展示)
File "pandas/_libs/parsers.pyx", line 720, in pandas._libs.parsers.TextReader._setup_parser_source

OSError: Initializing from file failed

 

相对于第一种情况很简单,原因就是没有把文件名称放到路径的后面,把文件名称添加到路径后面就可以了。还可以在代码中把文件夹切换到目标文件所在文件夹,过程太繁杂,不喜欢也不推荐,所以就不做展示了。
第二种情况,即使路径、文件名都完整,还是报错的原因是这个参数中有中文,但是Python3不是已经支持中文了吗?参考了错误原因和pandas的源码,发现调用pandas的read_csv()方法时,默认使用C engine作为parser engine,而当文件名中含有中文的时候,用C engine在部分情况下就会出错。所以在调用read_csv()方法时指定engine为Python就可以解决问题了。

 

df_Iris=pd.read_csv('D:\\数据源\\20220303CS607Pkey10000ID.csv',engine='python')

 

相对于第二种情况还有另外一种解决方法,就是使用open函数打开文件,再取访问里面的数据:

df_Iris =pd.read_csv(open('D:\\2.0 数据源\\20220303CS607Pkey10000ID.csv'))

 

OK,这个报错的原因都了解了,解决方法也很简单粗暴,是不是很简短简单!建议英文路径,也就不会报错啦!

import pandas as pd
df_Iris = pd.read_csv('D:\\MESNACWork\\10DataSetTest\\CS607SELECTED20220307.csv',delimiter=',',encoding='utf-8')

以上。

posted on   sduSRZ  阅读(471)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示