1

我正在尝试使用 python 和 pydub 库将大型播客 mp3 文件拆分为更小的 5 分钟块。这是我的代码:

folder = r"C:\temp"
filename = r"p967.mp3"

from pydub import AudioSegment

sound = AudioSegment.from_mp3(folder + "\\" + filename)

这适用于小文件,但对于我对 100mb + 感兴趣的大型播客。这将返回以下错误。

Traceback (most recent call last):    
  File "C:\temp\mp3split.py", line 6, in <module>
sound = AudioSegment.from_mp3(folder + "\\" + filename)
  File "C:\Python27\lib\site-packages\pydub\audio_segment.py", line 522, in from_mp3
return cls.from_file(file, 'mp3', parameters)
  File "C:\Python27\lib\site-packages\pydub\audio_segment.py", line 511, in from_file
obj = cls._from_safe_wav(output)
  File "C:\Python27\lib\site-packages\pydub\audio_segment.py", line 544, in _from_safe_wav
return cls(data=file)
  File "C:\Python27\lib\site-packages\pydub\audio_segment.py", line 146, in __init__
data = data if isinstance(data, (basestring, bytes)) else data.read()
MemoryError

这是图书馆的限制吗?我应该使用替代方法来实现这一目标吗?


如果我添加以下代码来检查运行时的内存状态。

import psutil
print psutil.virtual_memory()

这打印:

svmem(total=8476975104L, available=5342715904L, percent=37.0 used=3134259200L, free=5342715904L)

这向我表明在操作开始时有足够的内存,尽管我很高兴被证明是错误的。

4

1 回答 1

2

是的,最可能的原因是您只是用完了可用内存。在执行该语句之前,您知道有多少可用内存吗?考虑在失败的语句之前插入一个系统调用(参见os包)。

于 2017-08-11T22:30:41.867 回答