zoukankan      html  css  js  c++  java
  • pandas.read_csv() 报错 OSError: Initializing from file failed,报错原因分析和解决方法

    参考资料: https://www.cnblogs.com/lijinze-tsinghua/p/9904165.html

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

    import pandas as pd
    da1=pd.read_csv('F:\数据源')
    da2=pd.read_csv('F:\2.0 数据源\工程清单.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就可以解决问题了。

    da4=pd.read_csv('F:\数据源\工程清单.csv',engine='python')

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

    da3=pd.read_csv(open('F:\4.0 居配工程监测\2.0 数据源\02.南京新居配工程清单.csv'))
  • 相关阅读:
    单例模式的奇幻漂流
    webmin安装简介
    Linux下添加磁盘创建lvm分区
    教训 Mac下装windows系统 失败后 磁盘空间丢失
    Mac下安装 php+nginx+mysql 开发环境
    记一次 nginx 504 Gateway Time-out
    twemproxy 安装
    centos6.7下 编译安装MySQL5.7
    vagrant 配置文件简析
    VNC配置连接远程服务器桌面-linuxwindows
  • 原文地址:https://www.cnblogs.com/runningRain/p/11449222.html
Copyright © 2011-2022 走看看