shell-script-pt
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [shell-script] Ocorrência em linha


From: Humberto Pereira
Subject: Re: [shell-script] Ocorrência em linha
Date: Thu, 04 May 2006 15:33:59 -0300
User-agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.0.2) Gecko/20060404 SeaMonkey/1.0.1

E ae pessoal,

        vamos lah tentar acertar esse sed.

[begnini@coke tmp]$ cat a.txt
IBL printer2 hppibr_[JBM05D]-BIBLIOTECA(acct=BIBL,user=BIBL,copies=2,hppibr,simplex,landscape,usletter).PCLprintsrv Apr 1 2006 02:48:53 Apr 1 2006 03:04:05 hppibr_[JBM05D]-BIBLIOTE 0002000010bin /O455.19 BIBL 2

samir printer1 hpdocuprintr_ifch-I-FIL-C-HUMANAS-090000-samir(acct=ifch,user=samir,copies=50,hpdocuprintr,UsLetter,duplex,Portrait,09000000000000)--00E).PCL.PCL printsrv May 2 2006 19:00:19 May 2 2006 20:13:06 hpdocuprintr_ifch-I-FIL- 0050000004bin /O3243.36 ifch 50
[begnini@coke tmp]$


Existe uma linha em branco entre as duas linhas, o q nao tem linha em branco significa q eh a mesma linha.

A primeira coisa q a gente quer eh o nome do usuario. Entao vamos pegar todos os caracteres do comeco da linha ateh o primeiro espaco (Isso vai funcionar como um awk ' { print $1 } ' a.txt).

[begnini@coke tmp]$ sed 's/^\([^ ]\+\) .*$/\1/' a.txt
IBL
samir

Agora nos queremos pegar o campo que tem o bin com os numeros antes (Nao vou cometer o mesmo erro da expressao passada :P). Vamos procurar por tudo q contenha numeros seguido de bin e que tenha um espaco antes.

[begnini@coke tmp]$ sed 's/^\([^ ]\+\) .* \([0-9]\+bin\) .*$/\1 \2/' a.txt
IBL 0002000010bin
samir 0050000004bin

Legal, temos os 2 campos. Agora temos q pegar o penultimo campo. Veja q o ultimo campo sempre sao numeros. Entao o q tiver espaco e numero e estiver no fim da linha a gente casa.

[begnini@coke tmp]$ sed 's/^\([^ ]\+\) .* \([0-9]\+bin\) .* [0-9]\+$/\1 \2/' a.txt
IBL 0002000010bin
samir 0050000004bin

Nossa expressao continua funcionando. Agora basta pegar o campo anterior (qquer coisa entre espacos) e mostrar ele.

[begnini@coke tmp]$ sed 's/^\([^ ]\+\) .* \([0-9]\+bin\) .* \([^ ]\+\) \+[0-9]\+$/\1 \2 \3/' a.txt
IBL 0002000010bin BIBL
samir 0050000004bin ifch

Bem, esses sao os campos que a gente precisa pegar. Um pouco trabalhoso, mas nada que ir dividindo o problema e testando passo a passo nao resolva.

[]s
Humberto Pereira


Mauricy Maiorino wrote:
BIBL tinha em outro exemplo que enviei, mas seguindo o exemplo abaixo, é uma linha por registro e a posição de cada campo é definida por estes "brancos". Isto é um log de impressão, e os nomes variam. Não sei se fui claro!!

Mauricy



Tiago Barcellos Peczenyj escreveu:
BIBL ? onde tem BIBL nesse arquivo ?

O que define a posição de cada campo nesse arquivo ? é uma linha por registro ?

On 5/4/06, Mauricy Maiorino <address@hidden> wrote:
Funcionou legal, agora, não querendo abusar, estou usando "vários" awk
para selecionar o que preciso, porém estou vendo que com o sed acho que
consigo "encurtar" o caminho.

Isto vai me ajudar muito, mas o que preciso mesmo são dos campos "BIBL"
(que pode variar o tamanho) o próprio campo contendo o "bin" e mais no
final novamente o "BIBL" (que também pode variar), como neste outro
exemplo abaixo:

samir               printer1
hpdocuprintr_ifch-I-FIL-C-HUMANAS-090000-samir(acct=ifch,user=samir,copies=50,hpdocuprintr,UsLetter,duplex,Portrait,09000000000000)--00E).PCL.PCL
printsrv                        May 2 2006 19:00:19 May 2 2006 20:13:06
hpdocuprintr_ifch-I-FIL-
0050000004bin
/O3243.36                       ifch            50

...onde eu precisaria dos campos "samir" "0050000004bin" "ifch"

Se alguém tiver alguma idéia eu agradeço muito.

Mauricy


reply via email to

[Prev in Thread] Current Thread [Next in Thread]