-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbulk_copy_files.py
55 lines (43 loc) · 2.35 KB
/
bulk_copy_files.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
import shutil
import time
import logging
from pathlib import Path
from tqdm import tqdm
def copy_file_to_multiple_directories(source_file, destination_folder):
"""Copies a file to all subdirectories within a directory."""
source_path = Path(source_file).resolve() # Crucial: Resolve the path
destination_dir = Path(destination_folder).resolve() #Crucial: Resolve the path
if not source_path.exists():
raise FileNotFoundError(f"Source file not found: {source_path}") #Print resolved path
if not destination_dir.exists():
raise NotADirectoryError(f"Destination folder not found: {destination_dir}") #Print resolved path
if not destination_dir.is_dir():
raise NotADirectoryError(f"Destination is not a directory: {destination_dir}")
logging.basicConfig(filename='copy_log.txt', level=logging.INFO,
format='%(asctime)s - %(levelname)s - %(message)s')
folders = [f for f in destination_dir.iterdir() if f.is_dir()]
total_copies = len(folders)
start_time = time.perf_counter()
with tqdm(total=total_copies, desc="Copying files", unit="file") as pbar:
for folder in folders:
destination_path = folder / source_path.name
try:
shutil.copy2(source_path, destination_path)
pbar.update(1)
pbar.set_description(f"Copying to {folder.name}")
except shutil.SameFileError:
logging.warning(f"Source and destination are the same: {destination_path}")
pbar.update(1)
except OSError as e:
logging.error(f"Error copying to {destination_path}: {e}")
pbar.update(1)
pbar.set_description(f"Error copying to {folder.name}")
elapsed_time = time.perf_counter() - start_time
logging.info(f"Total files copied: {total_copies}")
logging.info(f"Time taken: {elapsed_time:.2f} seconds")
if __name__ == "__main__":
source_file = Path("F:/Mangas/000_res.png") # Forward slashes are more portable
destination_folder = Path("./Until-You-Confess-translated")
print(f"Source Path (before resolve): {source_file}") #Debug print
print(f"Destination Path (before resolve): {destination_folder}") #Debug print
copy_file_to_multiple_directories(source_file, destination_folder)