![Как удалить/заменить все в столбце после определенного символа, извлеченного с помощью awk?](https://rvso.com/image/97211/%D0%9A%D0%B0%D0%BA%20%D1%83%D0%B4%D0%B0%D0%BB%D0%B8%D1%82%D1%8C%2F%D0%B7%D0%B0%D0%BC%D0%B5%D0%BD%D0%B8%D1%82%D1%8C%20%D0%B2%D1%81%D0%B5%20%D0%B2%20%D1%81%D1%82%D0%BE%D0%BB%D0%B1%D1%86%D0%B5%20%D0%BF%D0%BE%D1%81%D0%BB%D0%B5%20%D0%BE%D0%BF%D1%80%D0%B5%D0%B4%D0%B5%D0%BB%D0%B5%D0%BD%D0%BD%D0%BE%D0%B3%D0%BE%20%D1%81%D0%B8%D0%BC%D0%B2%D0%BE%D0%BB%D0%B0%2C%20%D0%B8%D0%B7%D0%B2%D0%BB%D0%B5%D1%87%D0%B5%D0%BD%D0%BD%D0%BE%D0%B3%D0%BE%20%D1%81%20%D0%BF%D0%BE%D0%BC%D0%BE%D1%89%D1%8C%D1%8E%20awk%3F.png)
Пример файла .txt:
/map/1.0.0/cd/base/4/23/82.png 200
/map/1.0.0/cd/base/2/48/154.png?fefsfes 200
/map/1.0.0/cd/base/3/45/433.png?gtdrdrg 200
Мне нужно удалить это:
.png
.png?fefsfes
.png?gtdrdrg
Я использую это
$ cat file.txt | awk '{ print $1","$2}'
чтобы получить результат:
/map/1.0.0/cd/base/4/23/82.png,200
/map/1.0.0/cd/base/2/48/154.png?fefsfes,200
/map/1.0.0/cd/base/3/45/433.png?gtdrdrg,200
Можно ли как-то извлечь столбец awk '{ print $1}'
и удалить все после последнего числа?
Желаемый результат:
/map/1.0.0/cd/base/4/23/82,200
/map/1.0.0/cd/base/2/48/154,200
/map/1.0.0/cd/base/3/45/433,200
решение1
Если вы хотите сохранить суть вашей команды awk, то вы можете просто sub
удалить ненужную конечную часть$1
awk '{sub(/\.png.*$/,"",$1); print $1","$2}' file
или (возможно, более неловко)
awk '{sub(/\.png.*$/,"",$1)}1' OFS=, file
решение2
Вы можете попробовать следующее решение awk -
awk 'BEGIN{FS=".png| "} {print $1,$NF}' kk.txt |tr ' ' ','
с использованием разделителя нескольких полей.