次のような複数行のテキストファイルがあります。
djfldfjd:lisa
ldj:roma
dkjdkjflddlsdkjdlkj:kathy
ldadkjfdsldkjdlkfjdlkkkkkkkkkkkkkkkkkkkkl:purple
dkjdljl:christine
kdllkldkjhhhhhhhhhhhhhhh:george
ldkjfdl:kathy
ここで必要なのは、上記のテキストファイルのすべての行を処理し、コロンの後に現れる文字列を比較し、コロンの後に繰り返される文字列を取得し、その文字列をコロンの前に印刷するスクリプトです。
だから私は以下のスクリプトを試してみましたが、以下のエラーが発生しました。
#!/usr/bin/sh
input="test.txt"
cat $input | while read line; do output= $(echo $line | cut -d":" -f2); done
for (( i = 0 ; i < "${#output[@]}" ; i++ ))
{
echo ${output[i]}
}
エラーメッセージ:
./compare.sh: line 11: test1: command not found
どんな助けでも大変感謝します。ありがとうございます。
答え1
スクリプトはsh
構文を使用しません。 kshとzshの構文が混在しているようです。基本的な構文チェックには、shellcheck(オンラインで利用可能またはシステムにインストールできるスタンドアロンユーティリティとして利用可能)を使用できます。
しかし、とにかくテキストを処理するにはシェルループを使用したくありません。。
むしろ、テキスト処理ツールを使用することをお勧めします。ここで、固定区切り文字を含むフィールドに書式設定されたテキストの場合は、次のようになりますawk
。
#! /usr/bin/sh -
input=test.txt
awk -F: '
second_pass {if (count[$2] > 1) print $1; next}
{count[$2]++}' "$input" second_pass=1 "$input"
答え2
わかりました。新しく追加した内容は次のとおりです。
awk -F: 'second_pass {if (count[$2] > 1) print NR-1 "," $1; next} {count[$2]++}' "$input" second_pass=1 "$input"
効果がある!乾杯! !