我试图获取种子名称或种子中的文件列表,而无需实际下载它们。
这是我当前的代码,它功能正常但速度很慢,因为它会下载种子内容。
import libtorrent as lt
import time
ses = lt.session()
params = {
'save_path': 'media/',
'storage_mode': lt.storage_mode_t(2),
'paused': False,
'auto_managed': True,
'duplicate_is_error': True
}
handle = lt.add_magnet_uri(ses, "magnet:?xt=urn:btih:9fea16aff4ece16e04f98321668a265f0fd22b7e&dn=archlinux-2017.08.01-x86_64.iso&tr=udp://tracker.archlinux.org:6969&tr=http://tracker.archlinux.org:6969/announce", params)
while(not handle.has_metadata()):
time.sleep(1)
print(handle.get_torrent_info().name())
我也尝试使用lt.parse_magnet_uri()
,但这不会返回我正在寻找的内容,或者真正通过信息哈希的大部分内容。
我最终通过利用params
中的'file_priorities'
属性解决了我的问题。但是,在检索元数据之前,这仍然会下载文件,因此我只是将它们保存到临时目录中。
import libtorrent as lt
import time
import tempfile
ses = lt.session()
params = {
'save_path': tempfile.mkdtemp(),
'storage_mode': lt.storage_mode_t(2),
'auto_managed': True,
'file_priorities': [0]*5
}
handle = lt.add_magnet_uri(ses, "magnet:?xt=urn:btih:9fea16aff4ece16e04f98321668a265f0fd22b7e&dn=archlinux-2017.08.01-x86_64.iso&tr=udp://tracker.archlinux.org:6969&tr=http://tracker.archlinux.org:6969/announce", params)
while(not handle.has_metadata()):
time.sleep(1)
print(handle.get_torrent_info().name())