This commit is contained in:
nilaoda 2024-12-01 00:33:51 +08:00
parent adbe376ae0
commit b044cdb305
2 changed files with 69 additions and 66 deletions

133
README.md
View File

@ -25,7 +25,7 @@ yay -Syu n-m3u8dl-re-git
# 命令行参数 # 命令行参数
``` ```
Description: Description:
N_m3u8DL-RE (Beta version) 20241020 N_m3u8DL-RE (Beta version) 20241201
Usage: Usage:
N_m3u8DL-RE <input> [options] N_m3u8DL-RE <input> [options]
@ -34,70 +34,73 @@ Arguments:
<input> 链接或文件 <input> 链接或文件
Options: Options:
--tmp-dir <tmp-dir> 设置临时文件存储目录 --tmp-dir <tmp-dir> 设置临时文件存储目录
--save-dir <save-dir> 设置输出目录 --save-dir <save-dir> 设置输出目录
--save-name <save-name> 设置保存文件名 --save-name <save-name> 设置保存文件名
--base-url <base-url> 设置BaseURL --base-url <base-url> 设置BaseURL
--thread-count <number> 设置下载线程数 [default: 本机CPU线程数] --thread-count <number> 设置下载线程数 [default: 本机CPU线程数]
--download-retry-count <number> 每个分片下载异常时的重试次数 [default: 3] --download-retry-count <number> 每个分片下载异常时的重试次数 [default: 3]
--force-ansi-console 强制认定终端为支持ANSI且可交互的终端 --http-request-timeout <seconds> HTTP请求的超时时间(秒) [default: 100]
--no-ansi-color 去除ANSI颜色 --force-ansi-console 强制认定终端为支持ANSI且可交互的终端
--auto-select 自动选择所有类型的最佳轨道 [default: False] --no-ansi-color 去除ANSI颜色
--skip-merge 跳过合并分片 [default: False] --auto-select 自动选择所有类型的最佳轨道 [default: False]
--skip-download 跳过下载 [default: False] --skip-merge 跳过合并分片 [default: False]
--check-segments-count 检测实际下载的分片数量和预期数量是否匹配 [default: True] --skip-download 跳过下载 [default: False]
--binary-merge 二进制合并 [default: False] --check-segments-count 检测实际下载的分片数量和预期数量是否匹配 [default: True]
--use-ffmpeg-concat-demuxer 使用 ffmpeg 合并时,使用 concat 分离器而非 concat 协议 [default: False] --binary-merge 二进制合并 [default: False]
--del-after-done 完成后删除临时文件 [default: True] --use-ffmpeg-concat-demuxer 使用 ffmpeg 合并时,使用 concat 分离器而非 concat 协议 [default: False]
--no-date-info 混流时不写入日期信息 [default: False] --del-after-done 完成后删除临时文件 [default: True]
--no-log 关闭日志文件输出 [default: False] --no-date-info 混流时不写入日期信息 [default: False]
--write-meta-json 解析后的信息是否输出json文件 [default: True] --no-log 关闭日志文件输出 [default: False]
--append-url-params 将输入Url的Params添加至分片, 对某些网站很有用, 例如 kakao.com [default: False] --write-meta-json 解析后的信息是否输出json文件 [default: True]
-mt, --concurrent-download 并发下载已选择的音频、视频和字幕 [default: False] --append-url-params 将输入Url的Params添加至分片, 对某些网站很有用, 例如 kakao.com [default: False]
-H, --header <header> 为HTTP请求设置特定的请求头, 例如: -mt, --concurrent-download 并发下载已选择的音频、视频和字幕 [default: False]
-H "Cookie: mycookie" -H "User-Agent: iOS" -H, --header <header> 为HTTP请求设置特定的请求头, 例如:
--sub-only 只选取字幕轨道 [default: False] -H "Cookie: mycookie" -H "User-Agent: iOS"
--sub-format <SRT|VTT> 字幕输出类型 [default: SRT] --sub-only 只选取字幕轨道 [default: False]
--auto-subtitle-fix 自动修正字幕 [default: True] --sub-format <SRT|VTT> 字幕输出类型 [default: SRT]
--ffmpeg-binary-path <PATH> ffmpeg可执行程序全路径, 例如 C:\Tools\ffmpeg.exe --auto-subtitle-fix 自动修正字幕 [default: True]
--log-level <DEBUG|ERROR|INFO|OFF|WARN> 设置日志级别 [default: INFO] --ffmpeg-binary-path <PATH> ffmpeg可执行程序全路径, 例如 C:\Tools\ffmpeg.exe
--ui-language <en-US|zh-CN|zh-TW> 设置UI语言 --log-level <DEBUG|ERROR|INFO|OFF|WARN> 设置日志级别 [default: INFO]
--urlprocessor-args <urlprocessor-args> 此字符串将直接传递给URL Processor --ui-language <en-US|zh-CN|zh-TW> 设置UI语言
--key <key> 设置解密密钥, 程序调用mp4decrpyt/shaka-packager进行解密. 格式: --urlprocessor-args <urlprocessor-args> 此字符串将直接传递给URL Processor
--key KID1:KEY1 --key KID2:KEY2 --key <key> 设置解密密钥, 程序调用mp4decrpyt/shaka-packager/ffmpeg进行解密. 格式:
对于KEY相同的情况可以直接输入 --key KEY --key KID1:KEY1 --key KID2:KEY2
--key-text-file <key-text-file> 设置密钥文件,程序将从文件中按KID搜寻KEY以解密.(不建议使用特大文件) 对于KEY相同的情况可以直接输入 --key KEY
--decryption-binary-path <PATH> MP4解密所用工具的全路径, 例如 C:\Tools\mp4decrypt.exe --key-text-file <key-text-file> 设置密钥文件,程序将从文件中按KID搜寻KEY以解密.(不建议使用特大文件)
--use-shaka-packager 解密时使用shaka-packager替代mp4decrypt [default: False] --decryption-engine <FFMPEG|MP4DECRYPT|SHAKA_PACKAGER> 设置解密时使用的第三方程序 [default: MP4DECRYPT]
--mp4-real-time-decryption 实时解密MP4分片 [default: False] --decryption-binary-path <PATH> MP4解密所用工具的全路径, 例如 C:\Tools\mp4decrypt.exe
-R, --max-speed <SPEED> 设置限速,单位支持 Mbps 或 Kbps15M 100K --mp4-real-time-decryption 实时解密MP4分片 [default: False]
-M, --mux-after-done <OPTIONS> 所有工作完成时尝试混流分离的音视频. 输入 "--morehelp mux-after-done" 以查看详细信息 -R, --max-speed <SPEED> 设置限速,单位支持 Mbps 或 Kbps15M 100K
--custom-hls-method <METHOD> 指定HLS加密方式 (AES_128|AES_128_ECB|CENC|CHACHA20|NONE|SAMPLE_AES|SAMPLE_AES_CTR|UNKNOWN) -M, --mux-after-done <OPTIONS> 所有工作完成时尝试混流分离的音视频. 输入 "--morehelp mux-after-done" 以查看详细信息
--custom-hls-key <FILE|HEX|BASE64> 指定HLS解密KEY. 可以是文件, HEX或Base64 --custom-hls-method <METHOD> 指定HLS加密方式 (AES_128|AES_128_ECB|CENC|CHACHA20|NONE|SAMPLE_AES|SAMPLE_AES_CTR|UNKNOWN)
--custom-hls-iv <FILE|HEX|BASE64> 指定HLS解密IV. 可以是文件, HEX或Base64 --custom-hls-key <FILE|HEX|BASE64> 指定HLS解密KEY. 可以是文件, HEX或Base64
--use-system-proxy 使用系统默认代理 [default: True] --custom-hls-iv <FILE|HEX|BASE64> 指定HLS解密IV. 可以是文件, HEX或Base64
--custom-proxy <URL> 设置请求代理, 如 http://127.0.0.1:8888 --use-system-proxy 使用系统默认代理 [default: True]
--custom-range <RANGE> 仅下载部分分片. 输入 "--morehelp custom-range" 以查看详细信息 --custom-proxy <URL> 设置请求代理, 如 http://127.0.0.1:8888
--task-start-at <yyyyMMddHHmmss> 在此时间之前不会开始执行任务 --custom-range <RANGE> 仅下载部分分片. 输入 "--morehelp custom-range" 以查看详细信息
--live-perform-as-vod 以点播方式下载直播流 [default: False] --task-start-at <yyyyMMddHHmmss> 在此时间之前不会开始执行任务
--live-real-time-merge 录制直播时实时合并 [default: False] --live-perform-as-vod 以点播方式下载直播流 [default: False]
--live-keep-segments 录制直播并开启实时合并时依然保留分片 [default: True] --live-real-time-merge 录制直播时实时合并 [default: False]
--live-pipe-mux 录制直播并开启实时合并时通过管道+ffmpeg实时混流到TS文件 [default: False] --live-keep-segments 录制直播并开启实时合并时依然保留分片 [default: True]
--live-fix-vtt-by-audio 通过读取音频文件的起始时间修正VTT字幕 [default: False] --live-pipe-mux 录制直播并开启实时合并时通过管道+ffmpeg实时混流到TS文件 [default: False]
--live-record-limit <HH:mm:ss> 录制直播时的录制时长限制 --live-fix-vtt-by-audio 通过读取音频文件的起始时间修正VTT字幕 [default: False]
--live-wait-time <SEC> 手动设置直播列表刷新间隔 --live-record-limit <HH:mm:ss> 录制直播时的录制时长限制
--live-take-count <NUM> 手动设置录制直播时首次获取分片的数量 [default: 16] --live-wait-time <SEC> 手动设置直播列表刷新间隔
--mux-import <OPTIONS> 混流时引入外部媒体文件. 输入 "--morehelp mux-import" 以查看详细信息 --live-take-count <NUM> 手动设置录制直播时首次获取分片的数量 [default: 16]
-sv, --select-video <OPTIONS> 通过正则表达式选择符合要求的视频流. 输入 "--morehelp select-video" 以查看详细信息 --mux-import <OPTIONS> 混流时引入外部媒体文件. 输入 "--morehelp mux-import" 以查看详细信息
-sa, --select-audio <OPTIONS> 通过正则表达式选择符合要求的音频流. 输入 "--morehelp select-audio" 以查看详细信息 -sv, --select-video <OPTIONS> 通过正则表达式选择符合要求的视频流. 输入 "--morehelp select-video" 以查看详细信息
-ss, --select-subtitle <OPTIONS> 通过正则表达式选择符合要求的字幕流. 输入 "--morehelp select-subtitle" 以查看详细信息 -sa, --select-audio <OPTIONS> 通过正则表达式选择符合要求的音频流. 输入 "--morehelp select-audio" 以查看详细信息
-dv, --drop-video <OPTIONS> 通过正则表达式去除符合要求的视频流. -ss, --select-subtitle <OPTIONS> 通过正则表达式选择符合要求的字幕流. 输入 "--morehelp select-subtitle" 以查看详细信息
-da, --drop-audio <OPTIONS> 通过正则表达式去除符合要求的音频流. -dv, --drop-video <OPTIONS> 通过正则表达式去除符合要求的视频流.
-ds, --drop-subtitle <OPTIONS> 通过正则表达式去除符合要求的字幕流. -da, --drop-audio <OPTIONS> 通过正则表达式去除符合要求的音频流.
--ad-keyword <REG> 设置广告分片的URL关键字(正则表达式) -ds, --drop-subtitle <OPTIONS> 通过正则表达式去除符合要求的字幕流.
--morehelp <OPTION> 查看某个选项的详细帮助信息 --ad-keyword <REG> 设置广告分片的URL关键字(正则表达式)
--version Show version information --disable-update-check 禁用版本更新检测 [default: False]
-?, -h, --help Show help and usage information --allow-hls-multi-ext-map 允许HLS中的多个#EXT-X-MAP(实验性) [default: False]
--morehelp <OPTION> 查看某个选项的详细帮助信息
--version Show version information
-?, -h, --help Show help and usage information
``` ```
<details> <details>

View File

@ -7,7 +7,7 @@
<ImplicitUsings>enable</ImplicitUsings> <ImplicitUsings>enable</ImplicitUsings>
<LangVersion>preview</LangVersion> <LangVersion>preview</LangVersion>
<Nullable>enable</Nullable> <Nullable>enable</Nullable>
<Version>0.2.1</Version> <Version>0.2.2</Version>
<Platforms>AnyCPU;x64</Platforms> <Platforms>AnyCPU;x64</Platforms>
</PropertyGroup> </PropertyGroup>