2013-07-23 2 views
2

Simple Awk avec plusieurs conditions à l'intérieur si avec un opérateur binaire. C'est cracher une erreur. Voir ci-dessous O/P.awk si avec plusieurs conditions jette erreur

D:\Program Files\Veritas\NetBackup\bin>bpdbjobs -report -most_columns | awk '{FS=","; if ($2 == 0 || $11 > 0) printf "%s,%s,%s,%d,%s,%s,%s,%d:%d:%d,%d,%d\n", $7,$5,$6,$4,$8,strftime("%c",$9),strftime("%c", $11),$10/(60*60),$10%(60*60)/60,$10%60,$16,$15}' > c:\bpdbjobs_report_processed.csv 
awk: cmd. line:2: {FS=","; if ($2 == 0 
awk: cmd. line:2:     ^unexpected newline or end of string 
'$11' is not recognized as an internal or external command, 
operable program or batch file. 

Un Snipped de quelques lignes à partir des données d'entrée est la suivante ...

 
23123,0,0,,xxxxxEX-IS,Daily-Differen-Noon,xxxxxex, ,1374573600,0000007052,0000000000, ,1,,,,,0,,root,1,16,1,9999,root,xxx-abc-nbkp,2,2,0,0,0,0,0,23123,,,,,,,,,,,,,0,0,0,0,0,,0,,,,Drives are in use in storage unit (xxx-abc-nbkp-hcart-robot-tld-0), 
23122,17,3,0,,,,,1374566996,0000000035,1374567031,,1,,,,,100,7644,root,,,,,,xxx-abc-nbkp,,,,,,0,0,,,,,,,,,,,,,,,,,,,,,,,, , 
23121,2,4,0,,,xxx-abc-BANCS1,xxx-abc-nbkp,1374557721,0000022931,0000000000,,1,,,,/backups/rpru/scripts/check_crs_listener.out,0,9628,root,,,,90000,root,xxx-abc-nbkp,,,,0,10,0,0,,,,,,,,,,xxx-abc-nbkp,,,,1,1,,,,,1,,,, , 
23120,0,1,,xxxxxEX-MB-BF,Daily,xxxxxex,xxx-abc-nbkp,1374555781,0000024871,0000000000,xxx-abc-nbkp-hcart-robot-tld-0,1,3,8579904,38000,/Microsoft Exchange Mailboxes/Nisha Jayadas [njayadas]/Top of Information Store/Inbox/FW: xxxxx Final Report for 30 Jun 2013\, 01 Jul 2013 and 02 Jul 2013 ,61,,root,0,16,4,0,other,xxx-abc-nbkp,3,3,0,0,55506,0,0,23120,346,,,,,,,,,,,0,0,0,0,0,0,xxxxxex_1374555781,1,,,0, , 
+0

Vous devrez peut-être Envelopper la condition 'if' dans un' {} '. Donc ce serait 'FS =", "; {si ... ' – fedorqui

+0

Merci pour la réponse. D: \ Program Files \ Veritas \ NetBackup \ bin> bpdbjobs -report -most_columns | awk '{FS = ","; {if ($ 2 == 0 || $ 11> 0) printf "% s,% s,% s,% d,% s,% s,% s,% d:% d:% d,% d,% d \ n ", $ 7, 5 $, 6 $, 4 $, 8 $, strftime ("% c ", 9 $), strftime ("% c ", 11 $), 10 $/(60 * 60), 10% (60 * 60)/60, $ 10% 60, $ 16, $ 15}} '> c: \ bpdbjobs_report_processed.csv awk: cmd. ligne: 2: {FS = ","; {if ($ 2 == 0 awk: cmd ligne: 2:^newline inattendu ou fin de chaîne '$ 11' n'est pas reconnu comme commande interne ou externe, programme exécutable ou fichier batch – senramesh

+0

Ensuite, vous pourriez mieux poster quelques données d'entrée afin que nous puissions vérifier – fedorqui

Répondre

2

En supposant que vous êtes sous Windows, modifiez votre ligne de commande:

awk -F, "{if ($2 == 0 || $11 > 0) printf \"%s,%s,%s,%d,%s,%s,%s,%d:%d:%d,%d,%d\n\", $7,$5,$6,$4,$8,strftime(\"%c\",$9),strftime(\"%c\", $11),$10/(60*60),$10%(60*60)/60,$10%60,$16,$15}" 
+0

captcha, Votre réponse semble être de me guider vers une réponse. Windows CMD en utilisant le terminal Cygwin Cela semble fonctionner correctement Laissez-moi vérifier complètement – senramesh

+0

Dans 'Cygwin', le guillemet est le même que dans bash/shell, mais le _error message_' n'est pas reconnu comme une commande interne ou externe, programme exécutable ou fichier batch.' est ** Windows **, pas Cygwin – captcha

+0

Merci yo tu, captcha. Cela a fait l'affaire. – senramesh

Questions connexes