【问题标题】:paramiko sftp get errorparamiko sftp 出错
【发布时间】:2013-08-03 01:45:31
【问题描述】:

我有以下代码,其中删除了凭据的初始化。 目录列表的打印工作,但是“获取”失败并出现以下异常

在我看来,预取失败了,因为我在 getfo 中提取了代码,并让它在我的代码中作为一个函数工作,并且预取被注释掉了。

有没有更好的解决方案?

*** Caught exception: <type 'exceptions.IOError'>: [Errno 2] The message [/Inbox/CD.BAIINT.D130802.T200541.M856559] is not extractable!
Traceback (most recent call last):
  File "C:\Projects\Python\SFTP\SFTPHSC.py", line 71, in <module>
    sftp.get(files, localpath + "/" + files)
  File "build\bdist.win-amd64\egg\paramiko\sftp_client.py", line 676, in get
    size = self.getfo(remotepath, fl, callback)
  File "build\bdist.win-amd64\egg\paramiko\sftp_client.py", line 640, in getfo
    file_size = self.stat(remotepath).st_size
  File "build\bdist.win-amd64\egg\paramiko\sftp_client.py", line 337, in stat
    t, msg = self._request(CMD_STAT, path)
  File "build\bdist.win-amd64\egg\paramiko\sftp_client.py", line 689, in _request
    return self._read_response(num)
  File "build\bdist.win-amd64\egg\paramiko\sftp_client.py", line 736, in _read_response
    self._convert_status(msg)
  File "build\bdist.win-amd64\egg\paramiko\sftp_client.py", line 762, in _convert_status
    raise IOError(errno.ENOENT, text)
IOError: [Errno 2] The message [/Inbox/CD.BAIINT.D130802.T200541.M856559] is not extractable!

username = ''
password=''
hostname =''
port=22
localpath ="c:/BkFiles/"
t = paramiko.Transport((hostname, port))

try:
    t.connect(username=username, password=password)
    sftp = paramiko.SFTPClient.from_transport(t)

    dirlist = sftp.listdir('.')
    print "Dirlist:", dirlist

    sftp.chdir('Inbox')
    dirlist = sftp.listdir('.')
    print "Dirlist:", dirlist

    for files in dirlist:
        sftp.get(files, localpath + files)
        print files
except Exception, e:
    print '*** Caught exception: %s: %s' % (e.__class__, e)
    traceback.print_exc()
finally:
     try:
        t.close()
     except:
        pass

【问题讨论】:

  • 您是否检查过这是否是凭据错误?您使用什么操作系统?您尝试提取的文件是由使用与此脚本不同的 UID 的程序生成的吗?
  • 凭据正确。正如我在帖子中所说,我可以打印目录中的文件。此外,我可以通过从 sftp_client.py 复制 getfo 函数的代码并在注释掉对 prefetch 的调用后直接调用它来解决这个问题。

标签: python sftp paramiko


【解决方案1】:

您遇到的具体错误可以在您的回溯中找到。查看Paramiko的sftp_client.py:760的源代码:

elif code == SFTP_NO_SUCH_FILE:
    raise IOError(errno.ENOENT, text)

1) 显然,您正在尝试 sftp 获取一个根本不存在的文件,或者将其保存到本地计算机上不存在的路径中。尝试修改您的代码以打印出您正在下载的路径以及保存到的位置:

for files in dirlist:
    print ' -> Attempting to download: "{}", and saving it {}'.format(files, localpath + files)
    sftp.get(files, localpath + files)
print files

2) 您可以将sftp.listdir('.') 缩短为sftp.listdir(),因为路径的默认参数已经是'.'

3) 您甚至可能希望打印出目标文件的统计信息以供进一步调试:

for files in dirlist:
    print ' -> Attempting to download: "{}", and saving it {}'.format(files, localpath + files)
    print ' --> remotepath stat: {}'.format(sftp.stat(files))
    sftp.get(files, localpath + files)
    print files

【讨论】:

  • +1 表示“下载”问题也可能是由于您希望将文件下载到的本地路径(文件夹)不存在。