Как использовать grep или любой другой инструмент для получения определенного значения в выводе

В приведенном ниже выводе мне нужно получить значение 255.00 в строке с Minimum: 255.00 (1.0000)

Шаблон как: Channel Statistics:\s+Gray:\s+Minimum: +([\d.]+)

Image: test.tif
  Format: TIFF (Tagged Image File Format)
  Geometry: 2525x1785
  Class: DirectClass
  Type: bilevel
  Depth: 1 bits-per-pixel component
  Channel Depths:
    Gray:     1 bits
  Channel Statistics:
    Gray:
      Minimum:                   255.00 (1.0000)
      Maximum:                   255.00 (1.0000)
      Mean:                      255.00 (1.0000)
      Standard Deviation:          0.00 (0.0000)
  Filesize: 581
  Interlace: No
  Orientation: Unknown
  Background Color: white
  Border Color: #DFDFDF
  Matte Color: #BDBDBD

3 ответа3

0

Это очень упрощенно, если предположить, что строка 'Minimum:' встречается ровно один раз в вашем входе

awk '/Minimum:/ {print $2}'
0

Используя perl, вы можете сделать следующее. Он захватывает числовое значение после minimum: внутри блока Channel Statistics: и печатает его:

perl -0 -ne '/Channel Statistics:\s+Gray:\s+Minimum:\h+([\d.]+)/ && print $1,"\n"' file

Вывод: (для данного примера)

255.00

Объяснение:

-0      # specifies the input record separator. If there are no digits, the null character is the separator. The whole file is read in a single string.
-n      # Iterate over the file
-e      # execute the command line

Regex:

/                           # regex delimiter
    Channel Statistics:     # literally
    \s+                     # 1 or more any kind of spaces
    Gray:                   # literally
    \s+                     # 1 or more any kind of spaces
    Minimum:                # literally
    \h+                     # 1 or more horizontal spaces
    (                       # start group 1
        [\d.]+              # 1 or more digit or dot
    )                       # end group
/                           # regex delimiter
0

С sed

sed -rn 's/^\s+Minimum:\s+([0-9.]+).+$/\1/p' image.data

В замедленном режиме:

  • -r рассказывает sed мы используем й extened регулярное выражение "синтаксис"
  • -n говорит sed не печатать несовпадающие строки
  • s/^\s+Minimum:\s+([0-9.]+).+$/\1/ соответствует вашей целевой строке и заменяет ее только тем значением, которое вы после
  • p говорит sed напечатать результат

Если вам необходимо устранить неоднозначность с учетом содержания предыдущих строк, это будет немного сложнее:

sed -r ':a;N;$!ba; s/^.*Gray:\s*\n\s+Minimum:\s+([0-9.]+).+$/\1/' image.data

где:

  • :a;N;$!ba; это цикл на языке sed который загружает весь файл одновременно
  • -n больше не нужен, так как нет других строк, которые мы не хотим печатать
  • последний p больше не нужен, так как мы не используем -n

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .