本项目参考NotebookLlama,是一个自动化生成视频的项目,通过从指定的URL获取内容,生成播客脚本,合成语音,生成图片,并最终生成视频。
华为 Mate 品牌盛典一文汇总:Mate 70、Mate X6、纯血鸿蒙、尊界 S800...
d9103400de0c59feda6c332dd832d583c34ad5ecfde664c33ac89da9.mp4
{
"topic": "华为盛典",
"dialogues": [
{
"speaker": "小简",
"contents": [
"各位,今天我们来聊聊华为的新鲜玩意儿,",
"Mate 70系列可谓是“史上最强大”的手机!",
"这名字可不是白叫的。"
]
},
{
"speaker": "老陈",
"contents": [
"史上最强大?",
"这名字听着可真有气势,",
"感觉就像是手机中的超人啊!",
"这手机要是跟我一起出门,",
"我得给它个超人披风!"
]
},
{
"speaker": "小简",
"contents": [
"你觉得这手机需要披风吗?",
"它已经有“金丝锦纤”和“东方锦色”这些高大上的名字了,",
"跟你一起跟风出门,",
"直接改成“锦衣卫”了!"
]
},
{
"speaker": "老陈",
"contents": [
"哈哈,我还想说,屏幕才真牛,",
"居然支持1-120Hz动态刷新率!",
"你说如果我老陈用上这个手机,",
"能不能比我老婆的语速还快?"
]
},
{
"speaker": "小简",
"contents": [
"这可难说,",
"她要是用心说话,120Hz也追不上,",
"更何况你右手太慢啊!",
"不过Mate 70的摄像头倒是真的不错,",
"5000万像素的变焦,",
"拍个远处的风景简直是“跨世代的远近”。"
]
},
{
"speaker": "老陈",
"contents": [
"我听说Mate 70还可以卫星寻呼?",
"那得多牛啊,",
"跟外星人聊天也不成问题了!",
"我觉得我可以问问外星人,",
"‘你们的手机是哪个品牌?’"
]
},
{
"speaker": "小简",
"contents": [
"哈哈,外星人肯定会告诉你,",
"他们那叫“银河手机”,",
"支持宇宙网络,",
"信号比你的流量卡强多了!"
]
},
{
"speaker": "老陈",
"contents": [
"说到流量卡,让我想到了“尊界 S800”!",
"这车启动得快得过飞机,",
"零百加速3.3秒,",
"难不成我坐上去能飞到北京喝咖啡?"
]
},
{
"speaker": "小简",
"contents": [
"当然能飞!",
"要是新保姆没跟上,坐在车里说:",
"‘我看了一下,今儿个下雪了,’",
"你直接跟她说,",
"‘没关系,我是高速通行证!’"
]
},
{
"speaker": "老陈",
"contents": [
"高速通行证!哈哈,",
"进到车顶上直接一键开启“智驾模式”,",
"那才是灵魂出窍的感觉。"
]
},
{
"speaker": "小简",
"contents": [
"没错!不过你知道吗,",
"这次发布会上还有一款腕表,",
"价格23999元,连黄金都镶嵌了。",
"要是我戴上这块表,",
"能不能让人以为我是在带财神?"
]
},
{
"speaker": "老陈",
"contents": [
"财神到!",
"难不成我也得给自己配一款手表,",
"看看哪个小区的老太太能先发现我。",
"我是“高贵大爷”?"
]
},
{
"speaker": "小简",
"contents": [
"哈哈,希望那时候你别把自己的老花镜丢了,",
"别到时候给新手表盖了膜,",
"结果只能当一块砖头,",
"用来阻挡阳光!"
]
},
{
"speaker": "老陈",
"contents": [
"说得好!",
"这华为盛典就像换头大戏,",
"都是高科技和奢华的再组合,",
"但归根结底,",
"我们还是要用心生活,",
"才能把生活过得金光闪闪!"
]
},
{
"speaker": "小简",
"contents": [
"没错!",
"不管技术多么牛,",
"最后生活中的快乐,",
"都是自主创造的!",
"希望每位朋友都能像华为的新品一样,",
"绽放出最精彩的光彩!",
"谢谢大家!"
]
}
]
}
.
├── app.py
├── config-template.toml
├── config.toml
├── main.py
├── requirements.txt
├── run.sh
├── utils/
│ ├── __init__.py
│ ├── config.py
│ ├── image.py
│ ├── llm.py
│ ├── log.py
│ ├── processing.py
│ ├── tts.py
│ └── video.py
└── web/
├── __init__.py
├── config.py
├── crud.py
├── database.py
├── models.py
├── schemas.py
├── service.py
└── web.py
-
克隆仓库到本地:
git clone https://github.com/chenwr727/URL2VideoStudio.git cd URL2VideoStudio
-
创建并激活虚拟环境:
python -m venv venv source venv/bin/activate # 对于Windows系统,使用 `venv\Scripts\activate`
-
安装依赖:
pip install -r requirements.txt
-
复制
config-template.toml
并重命名为config.toml
:cp config-template.toml config.toml
-
编辑
config.toml
文件,填写相应的API密钥和配置。
-
启动FastAPI应用:
python app.py
-
启动Streamlit应用:
streamlit run web.py --server.port 8000
-
运行
main.py
脚本处理指定URL:python main.py <url>
-
使用
run.sh
脚本管理服务:# 启动服务 ./run.sh start # 停止服务 ./run.sh stop # 重启服务 ./run.sh restart
- 从指定URL获取内容并解析。
- 使用LLM生成播客脚本。
- 合成语音并生成音频文件。
- 生成图片。
- 合成视频并生成最终视频文件。
- 提供基于FastAPI的API接口和基于Streamlit的Web界面。
app.py
:FastAPI应用入口。main.py
:主脚本,处理URL并生成视频。utils/
:工具模块,包括配置加载、日志记录、图像生成、LLM处理、语音合成、视频处理等。web/
:Web相关模块,包括数据库、模型、CRUD操作、服务等。web.py
:Streamlit应用入口。run.sh
:管理服务的Shell脚本。config-template.toml
:配置模板文件。requirements.txt
:项目依赖列表。
以下是一个示例命令,用于处理指定的URL并生成视频:
python main.py https://example.com/article
欢迎贡献代码!请提交Pull Request或报告问题。具体步骤如下:
- Fork 本仓库。
- 创建新分支 (
git checkout -b feature/new-feature
)。 - 提交更改 (
git commit -am 'Add some feature'
)。 - 推送到新分支 (
git push origin feature/new-feature
)。 - 提交Pull Request。
此项目使用MIT许可证。详情参见 LICENSE 文件。