mirror of
https://github.com/k4yt3x/video2x.git
synced 2025-01-01 10:29:09 +00:00
fixed bulk processing file output issues
This commit is contained in:
parent
16389fc8a6
commit
9389511d2d
109
src/upscaler.py
109
src/upscaler.py
@ -478,6 +478,8 @@ class Upscaler:
|
|||||||
input_file_type = input_file_mime_type.split('/')[0]
|
input_file_type = input_file_mime_type.split('/')[0]
|
||||||
input_file_subtype = input_file_mime_type.split('/')[1]
|
input_file_subtype = input_file_mime_type.split('/')[1]
|
||||||
|
|
||||||
|
Avalon.debug_info(_('File MIME type: {}').format(input_file_mime_type))
|
||||||
|
|
||||||
# set default output file suffixes
|
# set default output file suffixes
|
||||||
# if image type is GIF, default output suffix is also .gif
|
# if image type is GIF, default output suffix is also .gif
|
||||||
if input_file_mime_type == 'image/gif':
|
if input_file_mime_type == 'image/gif':
|
||||||
@ -694,71 +696,74 @@ class Upscaler:
|
|||||||
Avalon.info(_('Upscaling completed'))
|
Avalon.info(_('Upscaling completed'))
|
||||||
Avalon.info(_('Average processing speed: {} seconds per frame').format(self.total_frames / (time.time() - upscale_begin_time)))
|
Avalon.info(_('Average processing speed: {} seconds per frame').format(self.total_frames / (time.time() - upscale_begin_time)))
|
||||||
|
|
||||||
# start handling output
|
# start handling output
|
||||||
# output can be either GIF or video
|
# output can be either GIF or video
|
||||||
if input_file_type == 'image' and input_file_subtype != 'gif':
|
if input_file_type == 'image' and input_file_subtype != 'gif':
|
||||||
|
|
||||||
# resize and output image to output_path
|
Avalon.info(_('Exporting image'))
|
||||||
self.process_pool.append(self.ffmpeg_object.resize_image([f for f in self.upscaled_frames.iterdir() if f.is_file()][0], output_path, output_width, output_height))
|
|
||||||
self._wait()
|
|
||||||
|
|
||||||
elif input_file_mime_type == 'image/gif' or input_file_type == 'video':
|
# resize and output image to output_path
|
||||||
|
self.process_pool.append(self.ffmpeg_object.resize_image([f for f in self.upscaled_frames.iterdir() if f.is_file()][0], output_path, output_width, output_height))
|
||||||
# if the desired output is gif file
|
|
||||||
if output_path.suffix.lower() == '.gif':
|
|
||||||
Avalon.info(_('Converting extracted frames into GIF image'))
|
|
||||||
gifski_object = Gifski(self.gifski_settings)
|
|
||||||
self.process_pool.append(gifski_object.make_gif(self.upscaled_frames, output_path, framerate, self.extracted_frame_format))
|
|
||||||
self._wait()
|
self._wait()
|
||||||
Avalon.info(_('Conversion completed'))
|
|
||||||
|
|
||||||
# if the desired output is video
|
# elif input_file_mime_type == 'image/gif' or input_file_type == 'video':
|
||||||
else:
|
else:
|
||||||
# frames to video
|
|
||||||
Avalon.info(_('Converting extracted frames into video'))
|
|
||||||
self.process_pool.append(self.ffmpeg_object.assemble_video(framerate, self.upscaled_frames))
|
|
||||||
# f'{scale_width}x{scale_height}'
|
|
||||||
self._wait()
|
|
||||||
Avalon.info(_('Conversion completed'))
|
|
||||||
|
|
||||||
try:
|
# if the desired output is gif file
|
||||||
# migrate audio tracks and subtitles
|
if output_path.suffix.lower() == '.gif':
|
||||||
Avalon.info(_('Migrating audio, subtitles and other streams to upscaled video'))
|
Avalon.info(_('Converting extracted frames into GIF image'))
|
||||||
self.process_pool.append(self.ffmpeg_object.migrate_streams(self.current_input_file,
|
gifski_object = Gifski(self.gifski_settings)
|
||||||
output_path,
|
self.process_pool.append(gifski_object.make_gif(self.upscaled_frames, output_path, framerate, self.extracted_frame_format))
|
||||||
self.upscaled_frames))
|
|
||||||
self._wait()
|
self._wait()
|
||||||
|
Avalon.info(_('Conversion completed'))
|
||||||
|
|
||||||
# if failed to copy streams
|
# if the desired output is video
|
||||||
# use file with only video stream
|
else:
|
||||||
except subprocess.CalledProcessError:
|
# frames to video
|
||||||
traceback.print_exc()
|
Avalon.info(_('Converting extracted frames into video'))
|
||||||
Avalon.error(_('Failed to migrate streams'))
|
self.process_pool.append(self.ffmpeg_object.assemble_video(framerate, self.upscaled_frames))
|
||||||
Avalon.warning(_('Trying to output video without additional streams'))
|
# f'{scale_width}x{scale_height}'
|
||||||
|
self._wait()
|
||||||
|
Avalon.info(_('Conversion completed'))
|
||||||
|
|
||||||
if input_file_mime_type == 'image/gif':
|
try:
|
||||||
# copy will overwrite destination content if exists
|
# migrate audio tracks and subtitles
|
||||||
shutil.copy(self.upscaled_frames / self.ffmpeg_object.intermediate_file_name, output_path)
|
Avalon.info(_('Migrating audio, subtitles and other streams to upscaled video'))
|
||||||
|
self.process_pool.append(self.ffmpeg_object.migrate_streams(self.current_input_file,
|
||||||
|
output_path,
|
||||||
|
self.upscaled_frames))
|
||||||
|
self._wait()
|
||||||
|
|
||||||
else:
|
# if failed to copy streams
|
||||||
# construct output file path
|
# use file with only video stream
|
||||||
output_file_name = f'{output_path.stem}{self.ffmpeg_object.intermediate_file_name.suffix}'
|
except subprocess.CalledProcessError:
|
||||||
output_video_path = output_path.parent / output_file_name
|
traceback.print_exc()
|
||||||
|
Avalon.error(_('Failed to migrate streams'))
|
||||||
|
Avalon.warning(_('Trying to output video without additional streams'))
|
||||||
|
|
||||||
# if output file already exists
|
if input_file_mime_type == 'image/gif':
|
||||||
# create temporary directory in output folder
|
# copy will overwrite destination content if exists
|
||||||
# temporary directories generated by tempfile are guaranteed to be unique
|
shutil.copy(self.upscaled_frames / self.ffmpeg_object.intermediate_file_name, output_path)
|
||||||
# and won't conflict with other files
|
|
||||||
if output_video_path.exists():
|
|
||||||
Avalon.error(_('Output video file exists'))
|
|
||||||
|
|
||||||
temporary_directory = pathlib.Path(tempfile.mkdtemp(dir=output_path.parent))
|
else:
|
||||||
output_video_path = temporary_directory / output_file_name
|
# construct output file path
|
||||||
Avalon.info(_('Created temporary directory to contain file'))
|
output_file_name = f'{output_path.stem}{self.ffmpeg_object.intermediate_file_name.suffix}'
|
||||||
|
output_video_path = output_path.parent / output_file_name
|
||||||
|
|
||||||
# move file to new destination
|
# if output file already exists
|
||||||
Avalon.info(_('Writing intermediate file to: {}').format(output_video_path.absolute()))
|
# create temporary directory in output folder
|
||||||
shutil.move(self.upscaled_frames / self.ffmpeg_object.intermediate_file_name, output_video_path)
|
# temporary directories generated by tempfile are guaranteed to be unique
|
||||||
|
# and won't conflict with other files
|
||||||
|
if output_video_path.exists():
|
||||||
|
Avalon.error(_('Output video file exists'))
|
||||||
|
|
||||||
|
temporary_directory = pathlib.Path(tempfile.mkdtemp(dir=output_path.parent))
|
||||||
|
output_video_path = temporary_directory / output_file_name
|
||||||
|
Avalon.info(_('Created temporary directory to contain file'))
|
||||||
|
|
||||||
|
# move file to new destination
|
||||||
|
Avalon.info(_('Writing intermediate file to: {}').format(output_video_path.absolute()))
|
||||||
|
shutil.move(self.upscaled_frames / self.ffmpeg_object.intermediate_file_name, output_video_path)
|
||||||
|
|
||||||
# increment total number of files processed
|
# increment total number of files processed
|
||||||
self.cleanup_temp_directories()
|
self.cleanup_temp_directories()
|
||||||
|
Loading…
Reference in New Issue
Block a user