diff - números de linha de saída

diff - números de linha de saída

Eu quero usar a ferramenta cli para comparação de arquivos e preciso do número da linha antes da linha de saída com a ajuda da qual eu poderia pular para a diferença de linha, porque eu uso uma ferramenta que entende para onde pular, se a linha começar assim:line-number: regular line contents

Então eu tentei diff, e ler a documentação parece ser possível:

  -D, --ifdef=NAME                output merged file with `#ifdef NAME' diffs
      --GTYPE-group-format=GFMT   format GTYPE input groups with GFMT
      --line-format=LFMT          format all input lines with LFMT
      --LTYPE-line-format=LFMT    format LTYPE input lines with LFMT
    These format options provide fine-grained control over the output
      of diff, generalizing -D/--ifdef.
    LTYPE is `old', `new', or `unchanged'.  GTYPE is LTYPE or `changed'.
    GFMT (only) may contain:
      %<  lines from FILE1
      %>  lines from FILE2
      %=  lines common to FILE1 and FILE2
      %[-][WIDTH][.[PREC]]{doxX}LETTER  printf-style spec for LETTER
        LETTERs are as follows for new group, lower case for old group:
          F  first line number
          L  last line number
          N  number of lines = L-F+1
          E  F-1
          M  L+1
      %(A=B?T:E)  if A equals B then T else E
    LFMT (only) may contain:
      %L  contents of line
      %l  contents of line, excluding any trailing newline
      %[-][WIDTH][.[PREC]]{doxX}n  printf-style spec for input line number
    Both GFMT and LFMT may contain:
      %%  %
      %c'C'  the single character C
      %c'\OOO'  the character with octal code OOO
      C    the character C (other characters represent themselves)

mas não há exemplo ou explicação sobre essa mudança complicada.

É possível obter essa saída diff? Se sim, como?

Responder1

Sim, é possível. Ao usar essas opções, o padrão é apenas imprimir cada linha. Isso é muito detalhado e não é o que você deseja.

diff --unchanged-line-format=""

eliminará as linhas que permanecem inalteradas, portanto agora apenas as linhas antigas e novas são produzidas.

diff --unchanged-line-format="" --new-line-format=":%dn: %L"

agora mostrará as novas linhas prefixadas por :<linenumber>:um espaço, mas ainda imprimirá as linhas antigas. Supondo que você queira eliminá-los,

diff --unchanged-line-format="" --old-line-format="" --new-line-format=":%dn: %L"

Se você quiser que as linhas antigas sejam impressas em vez das novas, troque-as.

Responder2

Às vezes, uma imagem ou exemplo vale mais que 1.000 palavras. Formei o seguinte pipeline para "comparar" dois dumps MySQL (estrutura) com base na wnoiseresposta acima (por favor, dê todos os votos positivos para wnoise).

Exemplo de números de linha lado a lado:

 diff   --unchanged-line-format="" --old-line-format="%dn: %L  " --new-line-format="| %dn: %L"  \
         ./20220202-msqldump.sql  ./20221130-msqldump.sql       |
     awk -e' /^[[:digit:]]+: )/{ previous = $0; next; } { print previous $0 }' |
     grep -v -e"ENGINE=InnoDB AUTO_INCREMENT="

Infelizmente descobri que a diffopção do: --side-by-sidenão é compatível com as opções de formato de linha.

Eliminar as linhas AUTO_INCREMENT me deixou com apenas duas diferenças: a data e assim por diante.

Sem o grepfiltro a saída fica assim:

5127: ) ENGINE=InnoDB AUTO_INCREMENT=340 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci; | 5105:) ENGINE=InnoDB AUTO_INCREMENT=271 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci; 5150: ) ENGINE=InnoDB AUTO_INCREMENT=895 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci; | 5128:) ENGINE=InnoDB AUTO_INCREMENT=763 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci; 5170: ) ENGINE=InnoDB AUTO_INCREMENT=1371 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci; | 5148: ) ENGINE=InnoDB AUTO_INCREMENT=1173 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;

Observe que os números das linhas não correspondem. Eu costumava meldverificar se as coisas estavam se alinhando primeiro.

informação relacionada