我有以下 bash 代码,它逐行循环遍历文本文件.. im 试图在每一行添加工作"前缀"前缀,但反而收到此错误:
rob@laptop:~/Desktop$ ./appendToFile.sh stusers.txt kp
stusers.txt
kp
./appendToFile.sh: line 11: /bin/sed: Argument list too long
115000_210org@house.com,passw0rd
这是 bash 脚本..
#!/bin/bash
file=$1
string=$2
echo "$file"
echo "$string"
for line in `cat $file`
do
sed -e 's/^/prefix/' $line
echo "$line"
done < $file
我在这里做错了什么?
更新: 执行文件正面操作会将所有行转储到终端的单行上,可能相关吗?
rob@laptop:~/Desktop$ head stusers.txt
rob@laptop:~/Desktop$ ouse.com,passw0rd
单行 awk 命令也应该可以解决问题:
awk '{print "prefix" $0}' file
关于您的原始错误:
./appendToFile.sh:第 11 行:/bin/sed:参数列表太长
问题出在以下代码行上:
sed -e 's/^/prefix/' $line
在此上下文中$line
是sed运行所针对的文件名。 要更正您的代码,您应该这样修复此行:
echo $line | sed -e 's/^/prefix/'
(另请注意,原始代码末尾不应包含< $file
。
威廉·珀塞尔(William Pursell)在他的两个建议中都正确地解决了这个问题。
但是,我相信您已经正确识别出原始文本文件存在问题。dos2unix
不会纠正此问题,因为它只会剥离行尾的回车窗口棒。 (但是,如果您尝试在Windows中读取Linux文件,则会得到一条没有返回的庞大行。
假设文本文件中的行尾字符不是问题,William Pursell,Andy Lester或nullrevolution的答案将起作用。
while read...
建议的变体:
while read -r line; do echo "PREFIX " $line; done < $file
这可以直接从 shell 运行(不需要批处理/脚本文件):
while read -r line; do echo "kp" $line; done < stusers.txt
整个循环可以替换为对整个文件进行操作的单个 sed 命令:
sed -e 's/^/prefix/' $file
Perl 的一种方法是:
perl -p -e's/^/prefix' filename
或
perl -p -e'$_ = "prefix $_"' filename
无论哪种情况,它都会从filename
读取并将前缀行打印到 STDOUT。
如果你添加一个-i
标志,那么Perl将就地修改文件。 你也可以指定多个文件名,Perl 会神奇地完成所有这些文件名。
而不是 for 循环,使用while read...
更合适:
while read -r line; do
do
echo "$line" | sed -e 's/^/prefix/'
done < $file
但是更简单的方法会好得多:
sed -e 's/^/prefix/' $file
使用 sed。只需更改单词prefix
.
sed -e 's/^/prefix/' file.ext
如果要将输出保存在另一个文件中
sed -e 's/^/prefix/' file.ext > file_new.ext
你不需要 sed,只需在 echo 命令中连接字符串即可
while IFS= read -r line; do
echo "prefix$line"
done < filename
循环遍历文件中的每个单词:
for line in `cat file`; ...
sed -i '1a
Your Text' file1 file2 file3
一个没有 sed/awk 和 while 循环的解决方案:
xargs -n1 printf "$prefix%sn" < "$file"