1

我试图只获取 torrent 名称或 torrent 中的文件列表,而不实际下载它们。

这是我当前的代码,它可以运行但速度很慢,因为它会下载 torrent 内容。

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(),但这并没有返回我正在寻找的内容,或者任何真正超过信息哈希的东西。

4

1 回答 1

2

我最终通过利用'file_priorities'. params但是,这仍然会下载文件,直到检索到元数据,所以我只是将它们保存到一个临时目录中。

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())
于 2017-08-13T19:24:09.667 回答