2016-07-20 4 views
3

[Lösung gefunden]Pandas.read_excel: Zugriff auf das Home-Verzeichnis

Ich habe etwas unerwartetes Verhalten auftreten, wenn mein Home-Verzeichnis versucht pandas.read_excel mit zuzugreifen.

Die Datei I

/users/isys/orsheridanmeth 

zu können zugreifen möchten gefunden, die ist, wo cd ~/ mich nimmt. Die Datei Ich mag würde für den Zugriff ist

'~/workspace/data/example.xlsx' 

Die folgenden Arbeiten in der Excel-Datei (mit import pandas as pd) zu lesen:

df = pd.read_excel('workspace/data/example_.xlsx', 'Sheet1') 

während

df = pd.read_excel('~/workspace/data/example.xlsx', 'Sheet1') 

gibt mir die folgende Fehlermeldung:

df = pd.read_excel('~/workspace/data/example.xlsx', 'Sheet1') 
Traceback (most recent call last): 
    File "https://stackoverflow.com/users/is/ahlpypi/egg_cache/i/ipython-3.2.0_1_ahl1-py2.7.egg/IPython/core/interactiveshell.py", line 3035, in run_code 
    exec(code_obj, self.user_global_ns, self.user_ns) 
    File "<ipython-input-397-4412a9e7c128>", line 1, in <module> 
    df = pd.read_excel('~/workspace/data/example.xlsx', 'Sheet1') 
    File "https://stackoverflow.com/users/is/ahlpypi/egg_cache/p/pandas-0.16.2_ahl1-py2.7-linux-x86_64.egg/pandas/io/excel.py", line 151, in read_excel 
    return ExcelFile(io, engine=engine).parse(sheetname=sheetname, **kwds) 
    File "https://stackoverflow.com/users/is/ahlpypi/egg_cache/p/pandas-0.16.2_ahl1-py2.7-linux-x86_64.egg/pandas/io/excel.py", line 188, in __init__ 
    self.book = xlrd.open_workbook(io) 
    File "https://stackoverflow.com/users/is/ahlpypi/egg_cache/x/xlrd-0.9.2-py2.7.egg/xlrd/__init__.py", line 394, in open_workbook 
    f = open(filename, "rb") 
IOError: [Errno 2] No such file or directory: '~/workspace/data/example.xlsx' 

pandas.read_csv funktionierte jedoch, wenn ich pd.read_csv('~/workspace/data/example.csv') verwendete.

Ich möchte weiterhin diese relativen Pfade zu Dateien verwenden. Eine Erklärung, warum dies nicht mit pandas.read_excel funktioniert?

Mit xlrd

bei der Verwendung von xlrd ich eine ähnliche Fehlermeldung erhalten:

import xlrd 
xl = xlrd.open_workbook('~/workspace/data/example.xlsx') 
Traceback (most recent call last): 
    File "https://stackoverflow.com/users/is/ahlpypi/egg_cache/i/ipython-3.2.0_1_ahl1-py2.7.egg/IPython/core/interactiveshell.py", line 3035, in run_code 
    exec(code_obj, self.user_global_ns, self.user_ns) 
    File "<ipython-input-403-90af31feff4b>", line 1, in <module> 
    xl = xlrd.open_workbook('~/workspace/data/example.xlsx') 
    File "https://stackoverflow.com/users/is/ahlpypi/egg_cache/x/xlrd-0.9.2-py2.7.egg/xlrd/__init__.py", line 394, in open_workbook 
    f = open(filename, "rb") 
IOError: [Errno 2] No such file or directory: '~/workspace/data/example.xlsx' 

[SOLUTION]

from os.path import expanduser as ospath 
df = pd.read_excel(ospath('~/workspace/data/example.xlsx'), 'Sheet1') 
+0

hilft Ich vermute, dass als 'read_excel' ist ein drittes Partei-Modul,' xlrd' in diesem Fall, dass es nicht damit umgehen kann, könnten Sie versuchen, direkt mit 'xlrd' Modul zu sehen, ob der Fehler passiert auch mit diesem Modul – EdChum

+0

Ich scheine den gleichen Fehler zu bekommen, wenn Sie 'xlrd 'verwenden. – oliversm

+0

Ich denke, in diesem Fall müssen Sie '~' erweitern, bevor Sie es an 'read_excel' übergeben – EdChum

Antwort

4

ich ~ glauben wird von der Shell erweitert - in In diesem Fall ist Ihr Code wörtlich versuchen, einen Pfad zu öffnen, der mit ~ beginnt. Seltsamerweise funktioniert das nicht. :-)

Versuchen Sie, den Pfad durch os.path.expanduser() zuerst - das sollte arbeiten, um die ~ Variable auf den realen Wert zu erweitern. Sie können auch in os.path.expandvars() suchen.

Hoffnung, die