Возвращает определенные поля, если соответствует дате

3
2017-11-27 20:11:13,632 INFO  abc: [java: Thread-389579]: Completed executing command
2017-11-27 20:11:13,632 INFO  abc: [java: Thread-389579]: OK
2017-11-27 20:11:13,632 INFO  abc: [java: Thread-389579]: <completed>
2017-11-27 20:11:13,632 INFO  abc: [java: Thread-389579]: release for adeo/student

Мои подходы:

awk 'today="$(date +'%Y-%m-%d')" ( = today) && /Completed executing command/ {cnr = NR} NR == (cnr+3) {gsub(/\/.*/,"",$NF); print $NF}' filename
awk 'today="$(date +'%Y-%m-%d')" ( == today) && /Completed executing command/ { cnr = NR } NR == (cnr+3) { sub("/.*","",$NF); print $NF }' filename

Мы хотим напечатать только adeo и student в двух разных переменных. Условие - если $ 1 равно текущей дате, тогда он должен искать Completed executing command во всем файле, а затем пропускать две строки, а затем печатать adeo и student . (Название adeo / student не исправлено, поэтому в приведенном выше случае мы хотим adeo и student, но если есть другое имя, это должно появиться вместо этого).

Из нашего подхода мы получаем только adeo . Как мы можем достичь этого, используя awk / sed / grep или любой другой инструмент?

    
задан Zanna 28.11.2017 в 02:28
источник

2 ответа

3

Из комментариев я получаю, что вы хотите, чтобы результат выглядел как name1=adeo name2=student . Если это так, попробуйте:

$ awk -v today="$(date +'%Y-%m-%d')"  ' == today && /Completed executing command/ { cnr = NR } cnr && NR == cnr+3 {sub(/\//, " name2=", $NF); print "name1="$NF }' filename
name1=adeo name2=student
    
ответ дан John1024 28.11.2017 в 03:08
источник
2

Один из способов, по которым вы можете обращаться с использованием внешних переменных, - это размещение today в среде и использование ENVIRON["today"] внутри awk . Использование gsub() также не нужно, если вы хотите просто получить имя и часть учащегося, и если они всегда будут последним элементом в строке.

$ today=$(date +'%Y-%m-%d') awk ' = ENVIRON["today"] && /Completed executing command/ {cnr = NR} NR == (cnr+3) {print $NF}' input.txt                                
adeo/student
    
ответ дан Sergiy Kolodyazhnyy 28.11.2017 в 04:33