![как удалить несколько столбцов в CSV, если строка имеет одинаковые значения, используя команду awk](https://rvso.com/image/168792/%D0%BA%D0%B0%D0%BA%20%D1%83%D0%B4%D0%B0%D0%BB%D0%B8%D1%82%D1%8C%20%D0%BD%D0%B5%D1%81%D0%BA%D0%BE%D0%BB%D1%8C%D0%BA%D0%BE%20%D1%81%D1%82%D0%BE%D0%BB%D0%B1%D1%86%D0%BE%D0%B2%20%D0%B2%20CSV%2C%20%D0%B5%D1%81%D0%BB%D0%B8%20%D1%81%D1%82%D1%80%D0%BE%D0%BA%D0%B0%20%D0%B8%D0%BC%D0%B5%D0%B5%D1%82%20%D0%BE%D0%B4%D0%B8%D0%BD%D0%B0%D0%BA%D0%BE%D0%B2%D1%8B%D0%B5%20%D0%B7%D0%BD%D0%B0%D1%87%D0%B5%D0%BD%D0%B8%D1%8F%2C%20%D0%B8%D1%81%D0%BF%D0%BE%D0%BB%D1%8C%D0%B7%D1%83%D1%8F%20%D0%BA%D0%BE%D0%BC%D0%B0%D0%BD%D0%B4%D1%83%20awk.png)
У меня такой вывод
4567,4567
5436,5436
1234,5678
Ожидаемый результат:
1234,5678
Попробовал команду ниже, но она удаляет столбец, а не строку.
awk -F, 'NF==2{NF-=1}NF<1{sub(/",.*/,"\"")}1' OFS=,
Спасибо за вашу помощь и предложения.
решение1
Как насчет этого
awk -F, '$1 != $2'
Это работает путем сравнения первых двух полей, разделенных comna. Каждое awk
утверждение имеет неявное { print }
, если явное утверждение не указано, и это то, что здесь используется. Результатом является то, что строка ввода печатается только тогда, когда два поля не совпадают.
решение2
Вот мое предложение sed
:
sed '/^\(.*\),\1$/d' file
Выход:
1234,5678