N_m3u8DL-RE/README.md

222 lines
10 KiB
Markdown
Raw Normal View History

2022-05-25 12:28:41 +00:00
# N_m3u8DL-RE
2022-11-26 20:02:53 +00:00
跨平台的DASH/HLS/MSS下载工具。支持点播、直播(DASH/HLS)。
2022-08-08 16:03:22 +00:00
2023-03-23 15:08:53 +00:00
[![img](https://img.shields.io/github/stars/nilaoda/N_m3u8DL-RE?label=%E7%82%B9%E8%B5%9E)](https://github.com/nilaoda/N_m3u8DL-RE) [![img](https://img.shields.io/github/last-commit/nilaoda/N_m3u8DL-RE?label=%E6%9C%80%E8%BF%91%E6%8F%90%E4%BA%A4)](https://github.com/nilaoda/N_m3u8DL-RE) [![img](https://img.shields.io/github/release/nilaoda/N_m3u8DL-RE?label=%E6%9C%80%E6%96%B0%E7%89%88%E6%9C%AC)](https://github.com/nilaoda/N_m3u8DL-RE/releases) [![img](https://img.shields.io/github/license/nilaoda/N_m3u8DL-RE?label=%E8%AE%B8%E5%8F%AF%E8%AF%81)](https://github.com/nilaoda/N_m3u8DL-RE) [![img](https://img.shields.io/github/downloads/nilaoda/N_m3u8DL-RE/total?label=%E4%B8%8B%E8%BD%BD%E9%87%8F)](https://github.com/nilaoda/N_m3u8DL-RE/releases)
2022-08-08 16:03:22 +00:00
---
2022-08-13 06:39:16 +00:00
版本较低的Windows系统自带的终端可能不支持本程序替代方案在 [cmder](https://github.com/cmderdev/cmder) 中运行。
2022-08-19 15:07:07 +00:00
Arch Linux 可以从 AUR 获取:[n-m3u8dl-re-bin](https://aur.archlinux.org/packages/n-m3u8dl-re-bin)、[n-m3u8dl-re-git](https://aur.archlinux.org/packages/n-m3u8dl-re-git)
```bash
# Arch Linux 及其衍生版安装 N_m3u8DL-RE 发行版
yay -Syu n-m3u8dl-re-bin
# Arch Linux 及其衍生版安装 N_m3u8DL-RE 开发版
yay -Syu n-m3u8dl-re-git
```
2022-08-19 15:07:07 +00:00
---
2022-10-24 02:39:37 +00:00
# 命令行参数
```
Description:
2023-06-14 17:09:22 +00:00
N_m3u8DL-RE (Beta version) 20230615
2022-10-24 02:39:37 +00:00
Usage:
N_m3u8DL-RE <input> [options]
Arguments:
<input> 链接或文件
Options:
--tmp-dir <tmp-dir> 设置临时文件存储目录
--save-dir <save-dir> 设置输出目录
--save-name <save-name> 设置保存文件名
--base-url <base-url> 设置BaseURL
2022-12-06 15:17:41 +00:00
--thread-count <number> 设置下载线程数 [default: 16]
2022-10-24 02:39:37 +00:00
--download-retry-count <number> 每个分片下载异常时的重试次数 [default: 3]
--auto-select 自动选择所有类型的最佳轨道 [default: False]
--skip-merge 跳过合并分片 [default: False]
--skip-download 跳过下载 [default: False]
--check-segments-count 检测实际下载的分片数量和预期数量是否匹配 [default: True]
--binary-merge 二进制合并 [default: False]
--del-after-done 完成后删除临时文件 [default: True]
2022-10-31 16:27:27 +00:00
--no-date-info 混流时不写入日期信息 [default: False]
2023-06-14 17:09:22 +00:00
--no-log 关闭日志文件输出 [default: False]
--write-meta-json 解析后的信息是否输出json文件 [default: True]
2022-10-24 02:39:37 +00:00
--append-url-params 将输入Url的Params添加至分片, 对某些网站很有用, 例如 kakao.com [default: False]
-mt, --concurrent-download 并发下载已选择的音频、视频和字幕 [default: False]
-H, --header <header> 为HTTP请求设置特定的请求头, 例如:
-H "Cookie: mycookie" -H "User-Agent: iOS"
--sub-only 只选取字幕轨道 [default: False]
2022-10-31 16:27:27 +00:00
--sub-format <SRT|VTT> 字幕输出类型 [default: SRT]
2022-10-24 02:39:37 +00:00
--auto-subtitle-fix 自动修正字幕 [default: True]
--ffmpeg-binary-path <PATH> ffmpeg可执行程序全路径, 例如 C:\Tools\ffmpeg.exe
--log-level <DEBUG|ERROR|INFO|OFF|WARN> 设置日志级别 [default: INFO]
--ui-language <en-US|zh-CN|zh-TW> 设置UI语言
--urlprocessor-args <urlprocessor-args> 此字符串将直接传递给URL Processor
--key <key> 设置解密密钥, 程序调用mp4decrpyt/shaka-packager进行解密. 格式:
--key KID1:KEY1 --key KID2:KEY2
--key-text-file <key-text-file> 设置密钥文件,程序将从文件中按KID搜寻KEY以解密.(不建议使用特大文件)
--decryption-binary-path <PATH> MP4解密所用工具的全路径, 例如 C:\Tools\mp4decrypt.exe
--use-shaka-packager 解密时使用shaka-packager替代mp4decrypt [default: False]
--mp4-real-time-decryption 实时解密MP4分片 [default: False]
-M, --mux-after-done <OPTIONS> 所有工作完成时尝试混流分离的音视频. 输入 "--morehelp mux-after-done" 以查看详细信息
2023-04-12 15:07:25 +00:00
--custom-hls-method <METHOD> 指定HLS加密方式 (AES_128|AES_128_ECB|CENC|CHACHA20|NONE|SAMPLE_AES|SAMPLE_AES_CTR|UNKNOWN)
2022-10-24 02:39:37 +00:00
--custom-hls-key <FILE|HEX|BASE64> 指定HLS解密KEY. 可以是文件, HEX或Base64
--custom-hls-iv <FILE|HEX|BASE64> 指定HLS解密IV. 可以是文件, HEX或Base64
--use-system-proxy 使用系统默认代理 [default: True]
--custom-proxy <URL> 设置请求代理, 如 http://127.0.0.1:8888
2022-12-06 15:17:41 +00:00
--task-start-at <yyyyMMddHHmmss> 在此时间之前不会开始执行任务
2022-10-24 02:39:37 +00:00
--live-perform-as-vod 以点播方式下载直播流 [default: False]
--live-real-time-merge 录制直播时实时合并 [default: False]
--live-keep-segments 录制直播并开启实时合并时依然保留分片 [default: True]
2022-12-10 08:11:44 +00:00
--live-pipe-mux 录制直播并开启实时合并时通过管道+ffmpeg实时混流到TS文件 [default: False]
2023-04-12 15:07:25 +00:00
--live-fix-vtt-by-audio 通过读取音频文件的起始时间修正VTT字幕 [default: False]
2022-10-24 02:39:37 +00:00
--live-record-limit <HH:mm:ss> 录制直播时的录制时长限制
--live-wait-time <SEC> 手动设置直播列表刷新间隔
--mux-import <OPTIONS> 混流时引入外部媒体文件. 输入 "--morehelp mux-import" 以查看详细信息
-sv, --select-video <OPTIONS> 通过正则表达式选择符合要求的视频流. 输入 "--morehelp select-video" 以查看详细信息
-sa, --select-audio <OPTIONS> 通过正则表达式选择符合要求的音频流. 输入 "--morehelp select-audio" 以查看详细信息
2023-04-12 15:07:25 +00:00
-ss, --select-subtitle <OPTIONS> 通过正则表达式选择符合要求的字幕流. 输入 "--morehelp select-subtitle" 以查看详细信息
2022-12-06 15:17:41 +00:00
-dv, --drop-video <OPTIONS> 通过正则表达式去除符合要求的视频流.
-da, --drop-audio <OPTIONS> 通过正则表达式去除符合要求的音频流.
-ds, --drop-subtitle <OPTIONS> 通过正则表达式去除符合要求的字幕流.
2022-10-24 02:39:37 +00:00
--morehelp <OPTION> 查看某个选项的详细帮助信息
--version Show version information
-?, -h, --help Show help and usage information
```
<details>
<summary>点击查看More Help</summary>
```
More Help:
--mux-after-done
所有工作完成时尝试混流分离的音视频. 你能够以:分隔形式指定如下参数:
* format=FORMAT: 指定混流容器 mkv, mp4
* muxer=MUXER: 指定混流程序 ffmpeg, mkvmerge (默认: ffmpeg)
* bin_path=PATH: 指定程序路径 (默认: 自动寻找)
2023-04-12 09:39:56 +00:00
* keep=BOOL: 混流完成是否保留文件 true, false (默认: false)
2022-10-24 02:39:37 +00:00
例如:
# 混流为mp4容器
-M format=mp4
# 使用mkvmerge, 自动寻找程序
-M format=mkv:muxer=mkvmerge
# 使用mkvmerge, 自定义程序路径
-M format=mkv:muxer=mkvmerge:bin_path="C\:\Program Files\MKVToolNix\mkvmerge.exe"
```
```
More Help:
--mux-import
混流时引入外部媒体文件. 你能够以:分隔形式指定如下参数:
* path=PATH: 指定媒体文件路径
* lang=CODE: 指定媒体文件语言代码 (非必须)
* name=NAME: 指定媒体文件描述信息 (非必须)
例如:
# 引入外部字幕
--mux-import path=zh-Hans.srt:lang=chi:name="中文 (简体)"
# 引入外部音轨+字幕
--mux-import path="D\:\media\atmos.m4a":lang=eng:name="English Description Audio" --mux-import path="D\:\media\eng.vtt":lang=eng:name="English (Description)"
```
```
More Help:
--select-video
通过正则表达式选择符合要求的视频流. 你能够以:分隔形式指定如下参数:
2023-03-01 14:49:04 +00:00
id=REGEX:lang=REGEX:name=REGEX:codec=REGEX:res=REGEX:frame=REGEX
2023-06-14 17:23:16 +00:00
segsMin=number:segsMax=number:ch=REGEX:range=REGEX:url=REGEX
plistDurMin=hms:plistDurMax=hms:for=FOR
2022-10-24 02:39:37 +00:00
* for=FOR: 选择方式. best[number], worst[number], all (默认: best)
例如:
# 选择最佳视频
-sv best
# 选择4K+HEVC视频
-sv res="3840*":codec=hvc1:for=best
2023-06-14 17:23:16 +00:00
# 选择长度大于1小时20分钟30秒的视频
-sv plistDurMin="1h20m30s":for=best
2022-10-24 02:39:37 +00:00
```
```
More Help:
--select-audio
通过正则表达式选择符合要求的音频流. 参考 --select-video
例如:
# 选择所有音频
-sa all
# 选择最佳英语音轨
-sa lang=en:for=best
# 选择最佳的2条英语(或日语)音轨
-sa lang="ja|en":for=best2
```
```
More Help:
--select-subtitle
通过正则表达式选择符合要求的字幕流. 参考 --select-video
例如:
# 选择所有字幕
-ss all
# 选择所有带有"中文"的字幕
-ss name="中文":for=all
```
</details>
2022-09-22 19:13:30 +00:00
# 运行截图
## 点播
2022-08-19 15:07:07 +00:00
2022-08-28 04:07:25 +00:00
![RE1](img/RE.gif)
还可以并行下载+自动混流
2022-09-19 14:47:20 +00:00
![RE2](img/RE2.gif)
2022-09-22 19:13:30 +00:00
## 直播
2022-09-19 14:47:20 +00:00
录制TS直播源
[click to show gif](http://pan.iqiyi.com/file/paopao/W0LfmaMRvuA--uCdOpZ1cldM5JCVhMfIm7KFqr4oKCz80jLn0bBb-9PWmeCFZ-qHpAaQydQ1zk-CHYT_UbRLtw.gif)
录制MPD直播源
2022-09-22 19:13:30 +00:00
[click to show gif](http://pan.iqiyi.com/file/paopao/nmAV5MOh0yIyHhnxdgM_6th_p2nqrFsM4k-o3cUPwUa8Eh8QOU4uyPkLa_BlBrMa3GBnKWSk8rOaUwbsjKN14g.gif)
录制过程中借助ffmpeg完成对音视频的实时混流
```
ffmpeg -readrate 1 -i 2022-09-21_19-54-42_V.mp4 -i 2022-09-21_19-54-42_V.chi.m4a -c copy 2022-09-21_19-54-42_V.ts
```
2022-12-10 09:04:27 +00:00
在新版本(>=v0.1.5)中,可以尝试开启 `live-pipe-mux` 来代替以上命令
2022-11-17 15:15:57 +00:00
2023-06-18 07:37:07 +00:00
**特别注意:如果网络环境不够稳定,请不要开启 `live-pipe-mux`。管道内数据读取由 ffmpeg 负责,在某些环境下容易丢失直播数据**
在新版本(>=v0.1.8)中,能够通过设置环境变量 `RE_LIVE_PIPE_OPTIONS` 来改变 `live-pipe-mux` 时 ffmpeg 的某些选项: https://github.com/nilaoda/N_m3u8DL-RE/issues/162#issuecomment-1592462532
2022-11-17 15:15:57 +00:00
## 赞助
<a href="https://www.buymeacoffee.com/nilaoda" target="_blank"><img src="https://cdn.buymeacoffee.com/buttons/default-orange.png" alt="Buy Me A Coffee" height="41" width="174"></a>