我正在尝试使用python和pydub库将大型播客mp3文件分割成更小的5分钟块。这是我的密码:
folder = r"C:\temp"
filename = r"p967.mp3"
from pydub import AudioSegment
sound = AudioSegment.from_mp3(folder + "\\" + filename)这对于小文件很好,但是对于我对100 in +感兴趣的大型播客来说却很好。这将返回以下错误。
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)这对我来说意味着在操作开始时有大量的记忆,尽管我很高兴被证明错了。
发布于 2017-08-11 22:30:41
是的,最有可能的原因是您已经耗尽了可用的内存。在执行该语句之前,您知道有多少可用内存吗?考虑在失败语句之前插入一个系统调用(请参阅os包)。
https://stackoverflow.com/questions/45644560
复制相似问题