我昨天尝试下载文本文件时刚刚遇到这个问题。不确定这是否是你正在做的事情,但既然你说它里面有 ASCII 垃圾,我假设你在文本编辑器中打开它,因为它应该是文本。
如果是这种情况,问题在于该文件是文本文件,而您正尝试以二进制模式下载它。
您想要做的是以 ASCII 传输模式检索文件。
tempFile = open(os.path.join(localDirectory,f),'w') # Changed 'wb' to 'w'
ftpSession.retrlines('RETR '+f,tempFile.write) # Changed retrbinary to retrlines
不幸的是,这会从文件中删除所有换行符。哎呀!
因此,您需要再次添加删除的换行符:
tempFile = open(os.path.join(localDirectory,f),'w')
textLines = []
ftpSession.retrlines('RETR '+f,textLines.append)
tempFile.write('\n'.join(textLines))
这应该可行,但看起来并不那么好。因此,一点点清理工作将使我们:
temporaryFile = open(os.path.join(localDirectory, currentFile), 'w')
textLines = []
retrieveCommand = 'RETR '
ftpSession.retrlines(retrieveCommand + currentFile, textLines.append)
temporaryFile.write('\n'.join(textLines))