Intereting Posts
Как я могу получить пять секунд данных, добавленных в конец файла? Почему 1MiB следует использовать при настройке первого раздела? Установка HP DeskJet 3520 в CUPS Удаление символов при именовании файлов или папок Использование вывода команды в printf в ksh Какие ключи генерируются во время установки Debian 7.4 (Wheezy)? Значок Dropbox tray не отображается в элементарной операционной системе Luna / Freya? Создайте и установите модуль ядра в определенный каталог / lib / module / * kernel vime regex не нужно \ убегать NTP не синхронизирует время даже с `tinker panic 0` в /etc/ntp.conf в Centos 7.3. Просмотр VM из приостановленного состояния Обнаружение мягких ссылок Не удается подключиться к моей системе Virtual Box Ubuntu Удалено / tmp случайно Как подключиться с удаленного сервера к моему компьютеру? Найти файлы рекурсивно, которые старше одного года и не принадлежат конкретному пользователю

поиск строк с помощью awk

У меня есть файл-1, у которого есть список идентификаторов транзакции.

Файл -1

201503301616|9b8791b3-f860-409f-aad0-24debf834c1b|10.233.18.29.677220869928387637969 201503301616|9b8791b3-f860-409f-aad0-24debf834c1b|11.233.18.29.677220869928387637969 201503301616|9b8791b3-f860-409f-aad0-24debf834c1b|12.233.18.29.677220869928387637969 

У меня есть файл-2, в котором есть журналы. У него могут быть трубы в другом месте. Так что труба не может использоваться как разделитель

Файл-2

 logline-1|somefield fdfdsff dfwwtwtwt **201503301616|9b8791b3-f860-409f-aad0-24debf834c1b|12.233.18.29.677220869928387637969** logline-2|somefield fdfdsff dfwwtwtwt **201503301616|9b8791b3-f860-409f-aad0-24debf834c1b|12.233.18.29.677220869928387637969** logline-3|somefield fdfdsff dfwwtwtwt **201503301616|9b8791b3-f860-409f-aad0-24debf834c1b|10.233.18.29.677220869928387637969** logline-4|somefield fdfdsff dfwwtwtwt **201503301616|9b8791b3-f860-409f-aad0-24debf834c1b|10.233.18.29.677220869928387637969** logline-5|somefield fdfdsff dfwwtwtwt **201503301616|9b8791b3-f860-409f-aad0-24debf834c1b|11.233.18.29.677220869928387637969** 

Как я могу использовать awk для чтения всего содержимого в файле-1 … grep в файле 2 и создать файл 3, который имеет (идентификатор транзакции – вхождения в файл 2)

Ожидаемый файл-3

 201503301616|9b8791b3-f860-409f-aad0-24debf834c1b|10.233.18.29.677220869928387637969 2 201503301616|9b8791b3-f860-409f-aad0-24debf834c1b|11.233.18.29.677220869928387637969 1 201503301616|9b8791b3-f860-409f-aad0-24debf834c1b|12.233.18.29.677220869928387637969 2 

Вы можете попробовать с awk:

 awk 'FNR == NR { v[$1] = 0; next; } { v[$4]++; } END { for (elem in v) { print elem, v[elem]; } }' File-1 File-2 >outfile 

Таким образом, результат будет:

 201503301616|9b8791b3-f860-409f-aad0-24debf834c1b|11.233.18.29.677220869928387637969 1 201503301616|9b8791b3-f860-409f-aad0-24debf834c1b|12.233.18.29.677220869928387637969 2 201503301616|9b8791b3-f860-409f-aad0-24debf834c1b|10.233.18.29.677220869928387637969 2 

Но опять же я не знаю, зачем вам 2 файла. Вы можете сделать это с помощью File-2:

 awk '{ v[$4]++; } END { for (elem in v) { print elem, v[elem]; } }' File-2 >outfile 

Результат будет таким же.