截取视频 截取mp4 视频缩放

目录

视频缩放保存

ffmpeg按帧截取视频,画质会降低:

[截取视频 按帧截取mp4](#截取视频 按帧截取mp4)


视频缩放保存

python 复制代码
import glob
import os
import random

import cv2
import imageio
import numpy as np


def video_small(video_path, output_dir):

    video_name = os.path.basename(video_path)
    out_path =output_dir+'/'+video_name
    cap = cv2.VideoCapture(video_path)

    # 获取帧率和分辨率
    fps = cap.get(cv2.CAP_PROP_FPS)
    width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))
    height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))

    # 创建 imageio 的写入器
    writer = imageio.get_writer(out_path, fps=fps)

    frame_id = 0
    while True:
        ret, image = cap.read()
        if not ret:
            break

        if np.prod(image.shape[:2]) > 1000 * 1500:
            x_scale = np.sqrt(1000 * 1500 / np.prod(image.shape[:2]))
            image = cv2.resize(image, None, fx=x_scale, fy=x_scale, interpolation=cv2.INTER_AREA)

        # OpenCV 是 BGR,imageio 需要 RGB
        frame_rgb = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)
        writer.append_data(frame_rgb)

        frame_id += 1

    cap.release()
    writer.close()

if __name__ == '__main__':

    base_dir=r"C:\Users\Administrator\Videos\yundong"
    to_dir = r"C:\Users\Administrator\Videos\yundong_s"
    os.makedirs(to_dir, exist_ok=True)
    file_list=glob.glob(os.path.join(base_dir,"*.mp4"))

    for video_path in file_list:
        print('start',video_path)
        video_small(video_path, to_dir)

ffmpeg按帧截取视频,画质会降低:

ffmpeg -i 5s.mp4 -vf "select='gte(n,18)',setpts=N/FRAME_RATE/TB" -c:v libx264 -crf 18 -preset veryslow -c:a copy output.mp4

截取视频 按帧截取mp4

python 复制代码
import random

import cv2
import imageio

# 打开原始视频
video_path = r"E:\data\tiaosheng\0706\5s.mp4"

out_path=r"E:\data\tiaosheng\0706\output.mp4"
cap = cv2.VideoCapture(video_path)

# 获取帧率和分辨率
fps = cap.get(cv2.CAP_PROP_FPS)
width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))
height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))
total_frames = int(cap.get(cv2.CAP_PROP_FRAME_COUNT))

# 创建 imageio 的写入器
writer = imageio.get_writer(out_path, fps=fps)

frame_id = 0
while True:
    ret, frame = cap.read()
    if not ret:
        break

    if frame_id >= 18:
        # OpenCV 是 BGR,imageio 需要 RGB
        frame_rgb = cv2.cvtColor(frame, cv2.COLOR_BGR2RGB)
        writer.append_data(frame_rgb)

    frame_id += 1

cap.release()
writer.close()
相关推荐
时空自由民.19 小时前
音视频图片压缩
音视频
日取其半万世不竭20 小时前
PeerTube 部署指南:自建视频托管平台
云原生·eureka·音视频
luoqice20 小时前
FLV文件解析
音视频
byte轻骑兵1 天前
【AVRCP】规范精讲[10]:链路管理器LM互操作规则与场景落地
人工智能·音视频·蓝牙·avrcp·音视频控制
JK Chen1 天前
faster_whisper,视频转文字,并生成字幕文件
python·whisper·音视频
Prannt2 天前
星朗智能语音——语音合成——上传文件配音
ai·音视频·语音识别
byte轻骑兵2 天前
【AVRCP】规范精讲[7]: 打通AVCTP互操作底层,吃透事务标签与分片规则
人工智能·音视频·avrcp·音视频控制
EasyGBS2 天前
国标GB28181视频平台EasyGBS即将重磅新增WHIP推流功能!低延迟直播体验再升级
音视频
jiejiejiejie_2 天前
Flutter for OpenHarmony 萌系实战合集:地图功能 + 音频播放一站式指南
flutter·音视频
jbk33112 天前
10分钟翻译一条视频,实现语音、字幕翻译后与画面同步对齐,视频翻译助手使用教程
人工智能·音视频·剪辑软件·剪映自动化软件