Я пытаюсь добавить некоторую информацию обо всех файлах торрентов в путь к таблице моей базы данных MySQL, но похоже, что у меня есть проблемы с PATH. Как вы видите, есть полный путь, и он даже обнаруживает «charlie.torrent», поэтому я не понимаю, в чем проблема.IOError: [Errno 2] Нет такого файла или каталога
Это мой код:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import mysql.connector
import bencode
import binascii
import hashlib
import os
import sys
conn = mysql.connector.connect(host="localhost",user="root",password="root", database="TORRENTS")
cursor = conn.cursor
path = "/home/florian/TorrentFiles"
dirs = os.listdir(path)
for file in dirs:
try:
with open(file, 'rb') as torrentfile:
torrent = bencode.bdecode(torrentfile.read())
user = ("torrent['info']['name']","torrent['info']['length'],'bytes'","(hashlib.sha1(bencode.bencode(torrent['info'])).hexdigest())")
cursor.execute("""INSERT INTO torrent_infos (Name, Size, Hash) VALUES(%s, %s, %s)""", user)
except bencode.BTL.BTFailure:
continue
conn.close()
И я действительно не понимаю, следующий вывод моего сценария:
[email protected]:/home/florian/Documents/mysite/polls# python bdd.py
Traceback (most recent call last):
File "bdd.py", line 17, in <module>
with open(file, 'rb') as torrentfile:
IOError: [Errno 2] No such file or directory: 'charlie.torrent'
Я уже имел взгляд к другим же предметам без каких-либо результатов.
вам нужно 'с открытым (путь + файл, 'rb') в качестве torrentfile:' – heinst
@heinst, имейте в виду, что 'path + file' - простая конкатенация. Если путь «/ home/user/torrents», тогда 'path + file' дает вам'/home/user/torrentscharlie.torrent'. Это также относительно специфично для платформы, поэтому вам нужно будет изменить код для путей в стиле Unix и в стиле Windows. Здесь вызывается 'os.path.join', поскольку он будет учитывать правильные разделители путей (хотя он не будет изменять сам путь). – paidhima