gpt4 book ai didi

bash - 在 bash 中循环读取文件会跳过第三行的前 2 个字符

转载 作者:行者123 更新时间:2023-12-04 22:51:54 25 4
gpt4 key购买 nike

#bin/bash
INPUT_DIR="$1"
INPUT_VIDEO="$2"
OUTPUT_PATH="$3"
SOURCE="$4"
DATE="$5"

INPUT="$INPUT_DIR/sorted_result.txt"
COUNT=1
initial=00:00:00
while IFS= read -r line; do
OUT_DIR=$OUTPUT_PATH/$COUNT
mkdir "$OUT_DIR"
ffmpeg -nostdin -i $INPUT_VIDEO -vcodec h264 -vf fps=25 -ss $initial -to $line $OUT_DIR/$COUNT.avi
ffmpeg -i $OUT_DIR/$COUNT.avi -acodec pcm_s16le -ar 16000 -ac 1 $OUT_DIR/$COUNT.wav
python3.6 /home/Video_Audio_Chunks_1.py $OUT_DIR/$COUNT.wav
python /home/transcribe.py --decoder beam --cuda --source $SOURCE --date $DATE --video $OUT_DIR/$COUNT.avi --out_dir "$OUT_DIR"
COUNT=$((COUNT + 1))
echo "--------------------------------------------------"
echo $initial
echo $line
echo "--------------------------------------------------"
initial=$line
done < "$INPUT"

这是我正在处理的代码。sorted_results.txt文件内容如下:

00:6:59
00:7:55
00:8:39
00:19:17
00:27:48
00:43:27

在读取文件时,它会跳过第三行的前两个字符,即它将其视为 :8:39,这会导致 ffmpeg 错误并且脚本停止。

然而,当我只打印变量 $INITIAL 和 $LINE 时,注释 ffmpeg 命令,值被正确打印,即与文件内容相同。

我认为 ffmpeg 命令以某种方式影响了文件读取过程或变量值。但我不明白怎么做?

请帮忙。

最佳答案

你的 bash read builtin command和第二个 ffmpeg 命令(用于音频)都从 STDIN 读取,这就是它们相互干扰的原因。您也可以在那里指定 -nostdin 或使用另一个文件描述符(此处使用数字 3)进行读取:

  while IFS= read -r -u 3 line; do
...
done 3< "$INPUT"

关于bash - 在 bash 中循环读取文件会跳过第三行的前 2 个字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51146890/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com