специальные строки grep / awk, основанные на определенных полях; с использованием переменной ksh с awk

У меня есть этот входной файл: file_in.txt (с разделителем по каналу )

3345:tyg|rty|27|0|0|ty6|{89|io|}62|0 3346:tyg|rtyuio|63|0|1|ty6|{89|gh|}45|0 3347:tyu|ray|24|0|0|ty6|{89|uh|}27|0 3348:tyg|rtoy|93|0|1|ty6|{89|yh|}1|0 3349:tyo|rtert|28|0|0|ty6|{89|gh|}27|0 

Я хочу получить только те строки, которые имеют значение 9-го поля как }27 используя '|' как разделитель, так что мой вывод должен быть:

  • awk или sed в нижнем регистре / в верхнем регистре только один символ в строке?
  • Как я могу оптимизировать эту команду Unix?
  • Только цифры sh и grep
  • Как умножить два столбца в awk?
  • awk: Как выбрать несколько подстрок из файла фиксированной длины?
  • Накопить имя файла в файле журнала, используя сценарий оболочки
  •  3347:tyu|ray|24|0|0|ty6|{89|uh|}27|0 3349:tyo|rtert|28|0|0|ty6|{89|gh|}27|0 

    Ниже команда отлично работает:

     awk -F"|" '{ if ($9 == "}27") print $0 }' file_in.txt 

    Но я хочу использовать переменную оболочки вместо "}27" для которой я пробовал это:

     taskid="}27" awk -v tid="$taskid" -F"|" '{ if ($9 == "}tid") print $0 }' file_in.txt 

    Пожалуйста, помогите мне выяснить, где я ошибаюсь в этой команде. Любые другие предложения команды для достижения того же оцениваются.

    Linux и Unix - лучшая ОС в мире.