【问题标题】:Pandas.read_excel: Accessing the home directoryPandas.read_excel:访问主目录
【发布时间】:2016-11-23 10:09:06
【问题描述】:

[找到解决方案]

我在尝试使用 pandas.read_excel 访问我的主目录时遇到了一些意外行为。

我想访问的文件可以在

找到
/users/isys/orsheridanmeth

这是cd ~/ 带我去的地方。我要访问的文件是

'~/workspace/data/example.xlsx'

在excel文件中读取以下工作(使用import pandas as pd):

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

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

给我以下错误:

df = pd.read_excel('~/workspace/data/example.xlsx', 'Sheet1')
Traceback (most recent call last):
  File "/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 "/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 "/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 "/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 但是在我使用 pd.read_csv('~/workspace/data/example.csv') 时有效。

我想继续使用这个文件的相对路径。任何解释为什么这不适用于pandas.read_excel

使用xlrd

使用xlrd 时出现类似错误:

import xlrd
xl = xlrd.open_workbook('~/workspace/data/example.xlsx')
Traceback (most recent call last):
  File "/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 "/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'

[解决方案]

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

【问题讨论】:

  • 我怀疑read_excel使用了第三方模块,xlrd在这种情况下无法处理,你可以尝试直接使用xlrd模块看看是否报错该模块也会发生
  • 我在使用 `xlrd' 时似乎遇到了同样的错误。
  • 我认为在这种情况下,您必须先扩展~,然后才能将其传递给read_excel

标签: python pandas path


【解决方案1】:

我相信~ 是由shell 扩展的——在这种情况下,您的代码实际上是在尝试打开以~ 开头的路径。奇怪的是,这不起作用。 :-)

首先尝试运行通过os.path.expanduser() 的路径 - 这应该可以将~ 变量扩展为实际值。

您可能还想查看os.path.expandvars()

希望有帮助

【讨论】:

    猜你喜欢
    • 2023-04-04
    • 2016-03-25
    • 2016-08-22
    • 2014-09-09
    • 2016-11-26
    • 2016-04-15
    • 2015-04-30
    • 1970-01-01
    • 2021-12-09
    相关资源
    最近更新 更多