mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-10-30 22:25:19 +00:00 
			
		
		
		
	 1b77b347d4
			
		
	
	1b77b347d4
	
	
	
		
			
			* Also deprecated --sponskrub-args Closes: https://github.com/ytdl-org/youtube-dl/issues/27593 Eg: `--postprocessor-args "VideoConvertor:-c:v h264_nvenc -preset slow"` Eg: `--postprocessor-args "SponsKrub:-include-selfpromo"` For backward compatibility, `--postprocessor-args args` is equivalent to: `--post-processor-args "sponskrub:" --post-processor-args "default:args"`
		
			
				
	
	
		
			45 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| from __future__ import unicode_literals
 | |
| 
 | |
| import re
 | |
| 
 | |
| from .common import PostProcessor
 | |
| 
 | |
| 
 | |
| class MetadataFromTitlePP(PostProcessor):
 | |
|     def __init__(self, downloader, titleformat):
 | |
|         super(MetadataFromTitlePP, self).__init__(downloader)
 | |
|         self._titleformat = titleformat
 | |
|         self._titleregex = (self.format_to_regex(titleformat)
 | |
|                             if re.search(r'%\(\w+\)s', titleformat)
 | |
|                             else titleformat)
 | |
| 
 | |
|     def format_to_regex(self, fmt):
 | |
|         r"""
 | |
|         Converts a string like
 | |
|            '%(title)s - %(artist)s'
 | |
|         to a regex like
 | |
|            '(?P<title>.+)\ \-\ (?P<artist>.+)'
 | |
|         """
 | |
|         lastpos = 0
 | |
|         regex = ''
 | |
|         # replace %(..)s with regex group and escape other string parts
 | |
|         for match in re.finditer(r'%\((\w+)\)s', fmt):
 | |
|             regex += re.escape(fmt[lastpos:match.start()])
 | |
|             regex += r'(?P<' + match.group(1) + '>.+)'
 | |
|             lastpos = match.end()
 | |
|         if lastpos < len(fmt):
 | |
|             regex += re.escape(fmt[lastpos:])
 | |
|         return regex
 | |
| 
 | |
|     def run(self, info):
 | |
|         title = info['title']
 | |
|         match = re.match(self._titleregex, title)
 | |
|         if match is None:
 | |
|             self.to_screen('Could not interpret title of video as "%s"' % self._titleformat)
 | |
|             return [], info
 | |
|         for attribute, value in match.groupdict().items():
 | |
|             info[attribute] = value
 | |
|             self.to_screen('parsed %s: %s' % (attribute, value if value is not None else 'NA'))
 | |
| 
 | |
|         return [], info
 |