It looks like you're referencing a filename pattern for a movie download ( Woh.Bhi.Din.The.2024.720p.HEVC.Web-... ), and you'd like me to around it.
@classmethod def parse(cls, filename: str) -> MediaMetadata: base = Path(filename).stem ext = Path(filename).suffix.lstrip('.')
@staticmethod def move_to_folder(src_path: Path, dest_root: Path, meta: MediaMetadata) -> Path: # Example folder: /Movies/Woh Bhi Din The (2024)/Woh Bhi Din The (2024) [720p HEVC WEB].mkv movie_folder = dest_root / f"meta.title (meta.year)" if meta.year else dest_root / meta.title movie_folder.mkdir(parents=True, exist_ok=True) new_name = FileOrganizer.generate_clean_name(meta) dest_path = movie_folder / new_name shutil.move(str(src_path), str(dest_path)) return dest_path if name == " main ": sample = "Woh.Bhi.Din.The.2024.720p.HEVC.WeB-NoGrp.mkv" parsed = MediaParser.parse(sample) print(parsed) # Output: # MediaMetadata(raw_name='Woh.Bhi.Din.The.2024.720p.HEVC.WeB-NoGrp.mkv', # title='Woh Bhi Din The', year=2024, resolution='720P', # codec='HEVC', source='WEB', group='NoGrp', extension='mkv')
meta = 'raw_name': filename, 'title': base, 'year': None, 'resolution': None, 'codec': None, 'source': None, 'group': None, 'extension': ext Download - Woh.Bhi.Din.The.2024.720p.HEVC.WeB-...
# Extract year year_match = re.search(cls.PATTERNS['year'], base) if year_match: meta['year'] = int(year_match.group()) # Remove year from title guess base = base.replace(year_match.group(), '')
# Extract resolution res_match = re.search(cls.PATTERNS['resolution'], base, re.IGNORECASE) if res_match: meta['resolution'] = res_match.group().upper()
# Extract codec codec_match = re.search(cls.PATTERNS['codec'], base, re.IGNORECASE) if codec_match: meta['codec'] = codec_match.group().upper() It looks like you're referencing a filename pattern
return MediaMetadata(**meta) class FileOrganizer: @staticmethod def generate_clean_name(meta: MediaMetadata) -> str: parts = [meta.title] if meta.year: parts.append(f"(meta.year)") details = [] if meta.resolution: details.append(meta.resolution) if meta.codec: details.append(meta.codec) if meta.source: details.append(meta.source) if details: parts.append(f"[' '.join(details)]") if meta.group: parts.append(f"-meta.group") return f"' '.join(parts).meta.extension"
# Clean title: replace dots/spaces, remove extra metadata clean_title = re.sub(r'[._-]', ' ', base) clean_title = re.sub(r'\b(720p|1080p|HEVC|WEB|BluRay|x264)\b', '', clean_title, flags=re.IGNORECASE) clean_title = ' '.join(clean_title.split()).strip() meta['title'] = clean_title or "Unknown"
# Extract source src_match = re.search(cls.PATTERNS['source'], base, re.IGNORECASE) if src_match: meta['source'] = src_match.group().upper() filename: str) ->
class MediaParser: # Regex patterns (flexible order) PATTERNS = 480p
# Extract release group group_match = re.search(cls.PATTERNS['group'], base) if group_match: meta['group'] = group_match.group('group')