Python讀取csv報(bào)錯(cuò)解決方法:OSError: Initializing from file failed

Python版本:Python 3.6
pandas.read_csv() 報(bào)錯(cuò) OSError: Initializing from file failed,一般由兩種情況引起:一種是函數(shù)參數(shù)為路徑而非文件名稱,另一種是函數(shù)參數(shù)帶有中文。

對于第一種情況很簡單,原因就是沒有把文件名稱放到路徑的后面,把文件名稱添加到路徑后面就可以了。還可以在代碼中把文件夾切換到目標(biāo)文件所在文件夾,過程太繁雜,不喜歡也不推薦,所以就不做展示了。
第二種情況,即使路徑、文件名都完整,還是報(bào)錯(cuò)的原因是這個(gè)參數(shù)中有中文,但是Python3不是已經(jīng)支持中文了嗎?參考了錯(cuò)誤原因和pandas的源碼,發(fā)現(xiàn)調(diào)用pandas的read_csv()方法時(shí),默認(rèn)使用C engine作為parser engine,而當(dāng)文件名中含有中文的時(shí)候,用C engine在部分情況下就會(huì)出錯(cuò)。所以在調(diào)用read_csv()方法時(shí)指定engine為Python就可以解決問題了。

da4=pd.read_csv('F:\數(shù)據(jù)源\工程清單.csv',engine='python')

對于第二種情況還有另外一種解決方法,就是使用open函數(shù)打開文件,再取訪問里面的數(shù)據(jù):

da3=pd.read_csv(open('F:\4.0 居配工程監(jiān)測\2.0 數(shù)據(jù)源\02.南京新居配工程清單.csv'))

好了這個(gè)報(bào)錯(cuò)的原因都了解了,解決方法也很簡單粗暴,是不是很簡短簡單!

作者:飛羽喂馬
來源:CSDN
原文:https://blog.csdn.net/qq_35318838/article/details/80564938
版權(quán)聲明:本文為博主原創(chuàng)文章,轉(zhuǎn)載請附上博文鏈接!

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容