截取视频 截取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()
相关推荐
REDcker5 天前
WebCodecs VideoDecoder 的 hardwareAcceleration 使用
前端·音视频·实时音视频·直播·webcodecs·videodecoder
gihigo19985 天前
基于TCP协议实现视频采集与通信
网络协议·tcp/ip·音视频
山河君5 天前
四麦克风声源定位实战:基于 GCC-PHAT + 最小二乘法实现 DOA
算法·音视频·语音识别·信号处理·最小二乘法·tdoa
音视频牛哥5 天前
Android平台RTMP/RTSP超低延迟直播播放器开发详解——基于SmartMediaKit深度实践
android·人工智能·计算机视觉·音视频·rtmp播放器·安卓rtmp播放器·rtmp直播播放器
qq_416276425 天前
通用音频表征的对比学习
学习·音视频
美狐美颜sdk5 天前
Android全局美颜sdk实现方案详解
人工智能·音视频·美颜sdk·视频美颜sdk·美狐美颜sdk
EasyDSS5 天前
私有化部署EasyDSS视频点播能力:全链路视频技术赋能,打造企业级视听新体验
音视频·hls·m3u8·点播技术·智能转码
qq_416276425 天前
DeLoRes——一种通用的音频表征学习新方法(DeLoRes(基于 Barlow Twins 的冗余最小化方法)
学习·音视频
Q_4582838685 天前
从定位到视频:808 + 1078 在各行业的落地实践
音视频
山顶望月川5 天前
实测MiniMax-Hailuo-02:当“开工大吉“变成“无字天书“,国产AI视频模型的能与之不能
人工智能·音视频