当前位置: 首页 > news >正文

python_基于主视频删减片段并插入镜头视频

python_基于主视频删减片段并插入镜头视频

importpyJianYingDraftasdraftfrompyJianYingDraftimporttrange,ClipSettings,tim def create_jianying_draft_from_clips(draft_name,main_video_path,delete_ranges,lens_info_dict,draft_folder_path):# 时间格式转换函数(处理00:00:01,640格式)def convert_time(time_str): h,m,s_ms=time_str.replace(',','.').split(':')returnf"{int(h)}h{int(m)}m{s_ms}s"# 1、创建草稿文件夹实例draft_folder=draft.DraftFolder(draft_folder_path)# 创建新草稿(使用主视频的分辨率)main_mat=draft.VideoMaterial(main_video_path)script=draft_folder.create_draft(draft_name,main_mat.width,main_mat.height,)# 2、计算出主视频的剩余目标区间并添加到草稿中def add_main_video_segments(): script.add_track(draft.TrackType.video,"video_track")# 创建视频轨道# 解析删除区间(转换为微秒,并按起始时间排序)parsed_deletes=[]forstart_str,end_strindelete_ranges:start=tim(convert_time(start_str))# 转换为微秒end=tim(convert_time(end_str))parsed_deletes.append((start,end))# 按起始时间排序,确保区间顺序正确(避免交叉区间导致计算错误)parsed_deletes.sort(key=lambda x: x[0])# 3. 获取视频总时长video_material=draft.VideoMaterial(main_video_path)total_duration=video_material.duration# 微秒# 4. 动态计算保留区间keep_ranges=[]prev_end=0# 上一个区间的结束位置fordelete_start,delete_endinparsed_deletes:# 若当前删除区间的起点 > 上一个区间的终点,说明中间有需要保留的部分ifdelete_start>prev_end: keep_ranges.append((prev_end,delete_start))# 更新上一个区间的终点为当前删除区间的终点prev_end=max(prev_end,delete_end)# 处理区间重叠的情况# 添加最后一个保留区间(从最后一个删除区间的终点到视频结束)ifprev_end<total_duration: keep_ranges.append((prev_end,total_duration))print("保留的视频片段时间区间",keep_ranges)# 5. 截取并拼接保留的片段current_start=0# 轨道上的起始位置(确保无缝拼接)forkeep_start,keep_endinkeep_ranges:ifkeep_start>=keep_end:continue# 跳过无效区间# 截取素材中[keep_start, keep_end)的片段segment=draft.VideoSegment(video_material,target_timerange=trange(current_start,keep_end-keep_start),# 轨道上的位置和时长source_timerange=trange(keep_start,keep_end-keep_start)# 素材中截取的区间)script.add_segment(segment,"video_track")current_start+=(keep_end-keep_start)# 更新下一段的起始位置# 3、添加镜头视频def add_lens_videos():forlens_name,lens_infoinlens_info_dict.items(): lens_video_path,lens_start_time=lens_info lens_video_material=draft.VideoMaterial(lens_video_path)start_time=tim(convert_time(lens_start_time))# 创建视频轨道script.add_track(draft.TrackType.video,track_name=lens_name,relative_index=1)# 创建镜头片段lens_segment=draft.VideoSegment(lens_video_material,trange(start_time,lens_video_material.duration),# 关键设置:强制缩放镜头视频以填充整个画布,确保完全覆盖clip_settings=ClipSettings(scale_x=main_mat.width/lens_video_material.width,# 按宽度比例缩放scale_y=main_mat.height/lens_video_material.height,# 按高度比例缩放))# 添加片段到对应轨道script.add_segment(lens_segment,lens_name)add_main_video_segments()add_lens_videos()script.save()draft_name="草稿名称4"main_video_path=r"C:\Users\Jordan\Downloads\【25-41格雷灰】【脚本_2】\【25-41格雷灰】【脚本_1】.mp4"delete_ranges=[("00:00:01,640","00:00:02,640"),("00:00:03,640","00:00:04,640")]lens_info_dict={"镜头A":[r"C:\Users\Jordan\Downloads\【25-41格雷灰】【脚本_2】\【25-41格雷灰】【镜头_拉链】.MP4","00:00:01,640"],"镜头B":[r"D:\Desktop\20251206223742_rec_.mp4","00:00:06,640"]} draft_folder_path=r"D:\download_software\JianyingPro Drafts"create_jianying_draft_from_clips(draft_name,main_video_path,delete_ranges,lens_info_dict,draft_folder_path)
http://www.rkmt.cn/news/94287.html

相关文章:

  • 2、Puppet入门:自动化配置管理解决方案
  • 3、使用Puppet创建首个清单及资源管理指南
  • 免费编程体验课寻课指南:优质平台与选择策略 - 品牌测评鉴赏家
  • 比手动快10倍!AI生成el-form-item代码实测
  • 4、使用Git管理Puppet代码
  • AI一键配置:用快马自动下载安装MinGW-w64环境
  • 23、跨平台系统管理与自动化脚本实践
  • 传统文件管理vsAlist:效率对比实测
  • AI自动解决iframe跨域问题:快马平台一键生成解决方案
  • Collections.singletonList在电商系统开发中的妙用
  • 8、Puppet编程:变量、表达式与系统信息的运用
  • bcryptjs是什么、加密和对比过程是怎样的(初级版)
  • SQL Server日期转换:传统方法与AI辅助效率对比
  • AI助力SQL Server 2016安装:自动生成安装脚本与配置指南
  • 【开题答辩全过程】以 雇主险信息管理系统为例,包含答辩的问题和答案
  • Python打印输出换行
  • 车辆MPC轨迹跟踪控制:双移线轨迹的追逐之旅
  • 3分钟原型开发:构建数组维度验证工具
  • AI如何帮你一键生成完美的JS深拷贝代码?
  • model.add
  • U盘无法访问:文件目录损坏且无法读取(上篇)
  • 企业级TLS升级实战:从TLSv1到TLSv1.2迁移指南
  • 探索MPC在电力电子与控制领域的奇妙之旅
  • 5分钟学会处理invalid_user_scode错误
  • 无刷直流电机模糊控制:Sfunction 函数与隶属度函数的奇妙之旅
  • 【开题答辩全过程】以 高校教材征订系统设计与开发为例,包含答辩的问题和答案
  • 我一个老运维,为啥把原版 Ubuntu 彻底卸了,换成这仨“亲儿子”
  • DataEase开源BI工具:如何选择最适合你的数据可视化版本
  • VSCode终极版 - 详解
  • WebSocket概念原理及使用注意事项 - 实践