[AI相关]生成视频-第一个项目,20k星开源MoneyPrinterTurbo

news/2025/2/22 1:41:34

还是之前文章介绍过地几个工具之一

[AI相关]各平台AI使用对比,包含大模型学习,生成视频等-CSDN博客

问问AI其结构,框架等,虽然不太完全对,但真地DeepSeek已经回答得很好了:

重点关注就两个类

  • video_engine和(实际上是video.py)
  • ai_generation(ai.py)

下面这个图,AI-DeepSeek直接给出得的是目录名,这就肯定不可能对的了,软件是不停迭代的,肯定会改名,也会在半年,一年内大幅度更新,目录名肯定不会“正确的”;但是整体框架(AI对框架的理解是非常好的,对我问的问题的立即也是非常好,这就。。。。。。。。非常恐怖了)

video.py

task.py 合成视频

# task.py
def generate_final_videos(
        task_id, params, downloaded_videos, audio_file, subtitle_path
):
    final_video_paths = []
    combined_video_paths = []
    video_concat_mode = (
        params.video_concat_mode if params.video_count == 1 else VideoConcatMode.random
    )

    _progress = 50
    for i in range(params.video_count):
        index = i + 1
        combined_video_path = path.join(
            utils.task_dir(task_id), f"combined-{index}.mp4"
        )
        logger.info(f"\n\n## combining video: {index} => {combined_video_path}")
        video.combine_videos(
            combined_video_path=combined_video_path,
            video_paths=downloaded_videos,
            audio_file=audio_file,
            video_aspect=params.video_aspect,
            video_concat_mode=video_concat_mode,
            max_clip_duration=params.video_clip_duration,
            threads=params.n_threads,
        )

最终还是回到 video.py

video.py 生成视频

def preprocess_video(materials: List[MaterialInfo], clip_duration=4):
    for material in materials:
        if not material.url:
            continue

        ext = utils.parse_extension(material.url)
        try:
            clip = VideoFileClip(material.url)
        except Exception:
            clip = ImageClip(material.url)

        width = clip.size[0]
        height = clip.size[1]
        if width < 480 or height < 480:
            logger.warning(f"video is too small, width: {width}, height: {height}")
            continue

python fileClip库

material.py

def download_videos(
    task_id: str,
    search_terms: List[str],
    source: str = "pexels",
    video_aspect: VideoAspect = VideoAspect.portrait,
    video_contact_mode: VideoConcatMode = VideoConcatMode.random,
    audio_duration: float = 0.0,
    max_clip_duration: int = 5,
) -> List[str]:
    valid_video_items = []
    valid_video_urls = []
    found_duration = 0.0
    search_videos = search_videos_pexels
    if source == "pixabay":
        search_videos = search_videos_pixabay

    for search_term in search_terms:
        video_items = search_videos(
            search_term=search_term,
            minimum_duration=max_clip_duration,
            video_aspect=video_aspect,
        )
        logger.info(f"found {len(video_items)} videos for '{search_term}'")

        for item in video_items:
            if item.url not in valid_video_urls:
                valid_video_items.append(item)
                valid_video_urls.append(item.url)
                found_duration += item.duration

    logger.info(
        f"found total videos: {len(valid_video_items)}, required duration: {audio_duration} seconds, found duration: {found_duration} seconds"
    )

logger 打印输出 

ai

《AI识别文字,视频稿部分》没写完

缺点?

基本上只是利用了pelex 等网站的视频搜索功能

(可以想象,是很传统的,标签tag管理,设置都没有什么多属性,多维度等科学的数据管理的)

然后,把搜索到的视频,胡乱拼凑

甚至都没有一点视频分析,视频AI自动生成地过程

整个项目地结构就是

(优点就是很简单,我这个0基础地门外汉,2个小时就把这个项目框架看透了)

1.基础框架steamlts

2.加上一点点功能,如互联网搜索,加上视频合成

3.最后辅佐上,最新人工智能AI-API地计息

4.当然,最后Python是一个很好的胶水作用,把各个功能有机地粘连在一起了


http://www.niftyadmin.cn/n/5861500.html

相关文章

JavaE E基础之 Tomcat与Http (上)

目录 1.Java WEB前奏 1.1. C/S 结构 1.2. B/S 结构 1.3. 静态网页和动态网页 1.4. 常见的网页 1.5. Web 服务器 2. Tomcat 安装(熟练) 2.1. Tomcat 概述 2.2. Tomcat 的作用 2.3 Tomcat 安装 2.4. Tomcat 测试 3. Tomcat 分析(熟练) 3.1. Tomcat 目录结构 3.2. Tomc…

Linux----Makefile基础

Makefile 是自动化构建工具 make 的配置文件&#xff0c;用于定义编译规则和依赖关系&#xff0c;实现高效增量编译。 初识makefile 1. 什么是 make&#xff1f; 定义&#xff1a; make 是一个命令行工具&#xff08;可执行程序&#xff09;&#xff0c;用于解析并执行 Makef…

Ubuntu 22.04 一键部署MinerU1.1.0

MinerU MinerU是一款将PDF转化为机器可读格式的工具&#xff08;如markdown、json&#xff09;&#xff0c;可以很方便地抽取为任意格式。 MinerU诞生于书生-浦语的预训练过程中&#xff0c;我们将会集中精力解决科技文献中的符号转化问题&#xff0c;希望在大模型时代为科技发…

VSCode集成deepseek使用介绍(Visual Studio Code)

VSCode集成deepseek使用介绍&#xff08;Visual Studio Code&#xff09; 1. 简介 随着AI辅助编程工具的快速发展&#xff0c;VSCode作为一款轻量级、高度可扩展的代码编辑器&#xff0c;已成为开发者首选的工具之一。DeepSeek作为AI模型&#xff0c;结合Roo Code插件&#x…

后端开发:开启技术世界的新大门

在互联网的广阔天地中&#xff0c;后端开发宛如一座大厦的基石&#xff0c;虽不直接与用户 “面对面” 交流&#xff0c;却默默地支撑着整个互联网产品的稳定运行。它是服务器端编程的核心领域&#xff0c;负责处理数据、执行业务逻辑以及与数据库和其他后端服务进行交互。在当…

使用API有效率地管理Dynadot域名,为域名部署DNS安全拓展(DNSSEC)

关于Dynadot Dynadot是通过ICANN认证的域名注册商&#xff0c;自2002年成立以来&#xff0c;服务于全球108个国家和地区的客户&#xff0c;为数以万计的客户提供简洁&#xff0c;优惠&#xff0c;安全的域名注册以及管理服务。 Dynadot平台操作教程索引&#xff08;包括域名邮…

Windows 图形显示驱动开发-CPU 内存调节和64KB 页面支持

对于 32 位 OS 离散图形处理单元 (GPU) 不支持可调整大小的 BAR&#xff0c;或者当调整帧缓冲区 BAR 的大小失败时&#xff0c;Windows 显示驱动程序模型 (WDDM) v2 将提供一种替代机制&#xff0c;通过该机制可以有效地访问离散 GPU VRAM。 对于支持可编程 BAR 地址空间的 GPU…

数据库配置文件

达梦数据库 修改dm.ini中的COMPATIBLE_MODE4,然后重启数据库 vi /dm8/data/DAMENG/dm.ini人大金仓数据库 修改kingbase.conf中的sql_mode‘’,然后重启数据库 vi /opt/package/Kingbase/ES/V8/data/kingbase.conf