Add length filter
This commit is contained in:
parent
c9685e6a3f
commit
ffdfa74abe
1 changed files with 42 additions and 7 deletions
|
|
@ -133,6 +133,8 @@ in
|
||||||
local playlist_mode=false
|
local playlist_mode=false
|
||||||
local max_downloads=""
|
local max_downloads=""
|
||||||
local custom_retries=""
|
local custom_retries=""
|
||||||
|
local min_duration=""
|
||||||
|
local max_duration=""
|
||||||
local url=""
|
local url=""
|
||||||
|
|
||||||
# Parse arguments
|
# Parse arguments
|
||||||
|
|
@ -142,7 +144,7 @@ in
|
||||||
playlist_mode=true
|
playlist_mode=true
|
||||||
shift
|
shift
|
||||||
;;
|
;;
|
||||||
-n|--max)
|
-n|--count)
|
||||||
max_downloads="$2"
|
max_downloads="$2"
|
||||||
shift 2
|
shift 2
|
||||||
;;
|
;;
|
||||||
|
|
@ -150,6 +152,14 @@ in
|
||||||
custom_retries="$2"
|
custom_retries="$2"
|
||||||
shift 2
|
shift 2
|
||||||
;;
|
;;
|
||||||
|
--min)
|
||||||
|
min_duration="$2"
|
||||||
|
shift 2
|
||||||
|
;;
|
||||||
|
--max)
|
||||||
|
max_duration="$2"
|
||||||
|
shift 2
|
||||||
|
;;
|
||||||
youtube|bilibili)
|
youtube|bilibili)
|
||||||
platform="$1"
|
platform="$1"
|
||||||
shift
|
shift
|
||||||
|
|
@ -165,15 +175,23 @@ in
|
||||||
|
|
||||||
# Validate inputs
|
# Validate inputs
|
||||||
if [[ -z "$platform" ]] || [[ -z "$url" ]]; then
|
if [[ -z "$platform" ]] || [[ -z "$url" ]]; then
|
||||||
echo "Usage: dlv <youtube|bilibili> [-p|--playlist] [-n|--max <number>] [-r|--retries <number>] <url>"
|
echo "Usage: dlv <youtube|bilibili> [OPTIONS] <url>"
|
||||||
echo ""
|
echo ""
|
||||||
echo "Arguments:"
|
echo "Arguments:"
|
||||||
echo " youtube|bilibili Platform to download from"
|
echo " youtube|bilibili Platform to download from"
|
||||||
echo ""
|
echo ""
|
||||||
echo "Options:"
|
echo "Options:"
|
||||||
echo " -p, --playlist Download as playlist"
|
echo " -p, --playlist Download as playlist"
|
||||||
echo " -n, --max <number> Limit number of videos to process/download"
|
echo " -n, --count <number> Limit number of videos to process/download"
|
||||||
echo " -r, --retries <number> Number of retry attempts (0 for no retries, default: 10)"
|
echo " -r, --retries <number> Number of retry attempts (0 for no retries, default: 10)"
|
||||||
|
echo " --min <minutes> Minimum video duration in minutes"
|
||||||
|
echo " --max <minutes> Maximum video duration in minutes"
|
||||||
|
echo ""
|
||||||
|
echo "Examples:"
|
||||||
|
echo " dlv youtube <url> - Download single YouTube video"
|
||||||
|
echo " dlv youtube -p <url> - Download YouTube playlist"
|
||||||
|
echo " dlv youtube --min 5 --max 30 <url> - Download videos between 5-30 minutes"
|
||||||
|
echo " dlv bilibili -p -n 10 <url> - Download first 10 videos from playlist"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
@ -195,6 +213,23 @@ in
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
# Build duration filter
|
||||||
|
local duration_filter=""
|
||||||
|
if [[ -n "$min_duration" ]] || [[ -n "$max_duration" ]]; then
|
||||||
|
local min_sec=""
|
||||||
|
local max_sec=""
|
||||||
|
[[ -n "$min_duration" ]] && min_sec=$((min_duration * 60))
|
||||||
|
[[ -n "$max_duration" ]] && max_sec=$((max_duration * 60))
|
||||||
|
|
||||||
|
if [[ -n "$min_sec" ]] && [[ -n "$max_sec" ]]; then
|
||||||
|
duration_filter="--match-filter \"duration >= $min_sec & duration <= $max_sec\""
|
||||||
|
elif [[ -n "$min_sec" ]]; then
|
||||||
|
duration_filter="--match-filter \"duration >= $min_sec\""
|
||||||
|
elif [[ -n "$max_sec" ]]; then
|
||||||
|
duration_filter="--match-filter \"duration <= $max_sec\""
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
# Build output template based on playlist mode
|
# Build output template based on playlist mode
|
||||||
local output_template
|
local output_template
|
||||||
if [[ "$playlist_mode" == true ]]; then
|
if [[ "$playlist_mode" == true ]]; then
|
||||||
|
|
@ -218,7 +253,7 @@ in
|
||||||
echo "Output directory: $DOWNLOAD_DIR/$platform_name"
|
echo "Output directory: $DOWNLOAD_DIR/$platform_name"
|
||||||
|
|
||||||
# Build command
|
# Build command
|
||||||
local cmd="yt-dlp $platform_flags"
|
local cmd="yt-dlp $platform_flags $duration_filter"
|
||||||
if [[ "$playlist_mode" == true ]]; then
|
if [[ "$playlist_mode" == true ]]; then
|
||||||
cmd="$cmd --yes-playlist"
|
cmd="$cmd --yes-playlist"
|
||||||
fi
|
fi
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue