[英]How to compare two strings in variables in bash
我想问一个问题:我有这样的事情。 WEDI_RC是一个txt文件,我想一行一行地读取它,将第一列存储到变量“ name”中。 当我回显第4行时,它成功写入了第一列($ 1)。 然后,我想将其与$ list进行比较,如果匹配,则将其添加到$ list并编写。 每个名字只写一次。 请参见下面的示例:
输入:
file1 1234 5667
file1 1234 4566
file1 1234 23456
file1 1234 23467
file2 1234 23456
file3 1234 12345
输出:
file1
file2
file3
我的代码:
list=""
while read -r line
do
name=$(echo $line | awk -F'[ ]' '{print $1}')
echo $name
if [ "$name" = "$list" ]; then
echo $name
list=$'$list\n$name'
echo "$list"
fi
done < $WEDI_RC
如果我理解正确,则希望从文件WEDI_RC
的第一列中获取唯一名称的列表。 如果是这样的话:
$ awk '{print $1}' WEDI_RC | sort -u
file1
file2
file3
也可以不使用sort
来完成,尽管不能保证名称的打印顺序:
$ awk '{a[$1]=1} END{for (name in a)print name}' WEDI_RC
file1
file2
file3
如果预先知道WEDI_RC文件中的名称已排序,则另一种方法是:
$ awk 'prior!=$1{print $1} {prior=$1}' WEDI_RC
file1
file2
file3
如果我理解您的要求,则希望显示在第一列中显示的不同名称,可以使用以下方法进行操作:
previousColumn=""
while read -r column1 column2 column3; do
if [ "$previousColumn" != "$column1" ]; then
echo "$column1"
previousColumn=$column1
fi
done < $WEDI_RC
回到基础知识,您应该使用cut -f1 -d" "
获取以空格字符分隔的第一列, sort
结果进行sort
以排序, sort
uniq
进行排序以显示uniq结果
cut -f1 -d" " WEDI_RC | sort | uniq
或其他答案中建议的sort -u
与sort | uniq
类似sort | uniq
sort | uniq
cut -f1 -d" " WEDI_RC | sort -u
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.