我试图在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()
,但这不会返回我要查找的内容,或者大部分内容都超过了信息哈希。
答案 0 :(得分: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())