我有一个 python 程序,需要 2 个参数输入文件和输出文件。它读取输入文件并创建该文件的副本,并在输出文件中进行一些修改。
我创建了一个带有一组参数的文本文件。它在多行上有多组参数。但是对于程序的1次执行,它需要逐行读取。因此每行都有 2 个参数(用空格分隔)要传递:输入文件和输出文件。
带有参数的文件示例(将其称为File-With-Multiple-Arguments-Per-Line.txt):
input-file-1-path/input-file-1-name.sql output-file-1-path/output-file-1-name.sql
input-file-2-path/input-file-2-name.sql output-file-2-path/output-file-2-name.sql
input-file-3-path/input-file-3-name.sql output-file-3-path/output-file-3-name.sql
input-file-4-path/input-file-4-name.sql output-file-4-path/output-file-4-name.sql
我试过这个:
for arg in $(< /Users/Repository/File-With-Multiple-Arguments-Per-Line.txt);
do python /Users/Git-Repos/MyProgram.py "$arg" "$arg" ;
done.
用法是这样的:python MyProgram.py input-file.txt output-file.txt
我做需要做的事。尽管由于某种原因它处理每个参数 3 次(因此,第一个参数是输入文件也被视为输出文件;与第二个参数相同)。所以我最终修改了输入文件,这是我不应该的。我知道这一点,因为输入和输出文件都是 2 个独立的 git 存储库。
我也只使用了一个"$arg"
,但后来我发现我的程序没有收到所需的第二个参数(输出文件)。我看到的不是我的输出文件,output: <stdout>
但是使用"$arg" "$arg"
会导致我的程序的错误解释。就好像同一个任务做了 3 次——第一次完成了预期的任务;第二次使用输入文件作为输出和输入;第三次使用输出文件作为输出和输入。
我也尝试了下面的解决方案,但是我的程序没有执行任何操作。尽管它在我的终端中显示输出,就好像它做了应该做的事情一样。并且没有出现错误。
仅供参考:从文件中读取 shell 脚本的多个参数
while read x y; do
python /Users/Git-Repos/MyProgram.py "$x" "$y"
done < /Users/Repository/File-With-Multiple-Arguments-Per-Line.txt