awk question


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting awk question
# 1  
Old 10-14-2010
awk question

Hello all,

I have ONE big xml file that contains hundreds of <JOB> ... </JOB> entries like the following:

Code:
  <JOB
   APPLICATION="APP"
   APR="0"
   AUG="0"
   AUTHOR="AUT"
   AUTOARCH="0"
   CMDLINE="/tmp/test1 %%var"
   CONFIRM="1"
   CREATION_DATE="20100430"
   CREATION_TIME="130739"
   CREATION_USER="user"
   CRITICAL="0"
   CYCLIC="0"
   CYCLIC_TYPE="Interval"
   DAYS_AND_OR="OR"
   DEC="0"
   DESCRIPTION="This is a test for"
   FEB="0"
   IND_CYCLIC="START"
   INTERVAL="00000M"
   JAN="0"
   JOBNAME="JOB1"
   JUL="0"
   JUN="0"
   MAR="0"
   MAXDAYS="0"
   MAXRERUN="0"
   MAXRUNS="0"
   MAXWAIT="20"
   MAY="0"
   MEMNAME="JOB1"
   MULTY_AGENT="N"
   NODEID="SERVER1"
   NOV="0"
   OCT="0"
   OWNER="root"
   RETRO="0"
   SEP="0"
   SHIFT="IGNOREJOB"
   SHIFTNUM="+00"
   SYSDB="0"
   TAG_RELATIONSHIP="OR"
   TASKTYPE="Command"
   USE_INSTREAM_JCL="N"
>
   <QUANTITATIVE NAME="DRIVE1" QUANT="1"/>
   <OUTCOND NAME="JOB1-OK" ODATE="ODAT" SIGN="ADD"/>
   <AUTOEDIT EXP="%%SYSTEM=server1"/>
  </JOB>
  <JOB>
  ....
  </JOB>

  <JOB>
  ....
  </JOB>

For each <JOB> ... </JOB> entrie I would like to update DESCRIPTION tag and add at the end of it the value of the variable %%SYSTEM like the following:

Code:
DESCRIPTION="This is a test for server1"

Cna someone help me please?

Thanks in advance
# 2  
Old 10-14-2010
Code:
perl -i -0pe 's/(?<=DESCRIPTION=")([^"]+)(.*?)(?<=%%SYSTEM=)([^"]+)/\1 \3\2\3/sg' file.xml

This User Gave Thanks to bartus11 For This Post:
# 3  
Old 10-14-2010
Hi bartus11,

Could you pleas explain the code ?
# 4  
Old 10-14-2010
Worked perfectly, thanks a lot bartus11!! Smilie

---------- Post updated at 02:10 PM ---------- Previous update was at 01:39 PM ----------

One more thing bartus11 Smilie

Always in each <JOB> ... </JOB> tag:

can you also help me how to delete lines containing <QUANTITATIVE NAME="DRIVE1" QUANT="1"/> when JOBNAME starts by JOB

and also how to add the same line contaning <QUANTITATIVE NAME="DRIVE2" QUANT="1"/> before <OUTCOND NAME....> when JOBNAME starts by JOB1 ?


Many thanks!

Last edited by cabrao; 10-14-2010 at 09:40 AM..
# 5  
Old 10-14-2010
Quote:
Originally Posted by cabrao
Worked perfectly, thanks a lot bartus11!! Smilie

---------- Post updated at 02:10 PM ---------- Previous update was at 01:39 PM ----------

One more thing bartus11 Smilie

Always in each <JOB> ... </JOB> tag:

can you also help me how to delete lines containing <QUANTITATIVE NAME="DRIVE1" QUANT="1"/> when JOBNAME starts by JOB

and also how to add the same line contaning <QUANTITATIVE NAME="DRIVE2" QUANT="1"/> before <OUTCOND NAME....> when JOBNAME starts by JOB1 ?


Many thanks!
Post sample input and desired output for those actions.
# 6  
Old 10-14-2010
Quote:
Originally Posted by bartus11
Post sample input and desired output for those actions.
OK I'll try to be more specific.

Can you help me with one command that deletes lines containing <QUANTITATIVE NAME="DRIVE1" QUANT="1"/> in all JOB entries when value of JOBNAME starts by JOB1. Desired output would be:

Code:
   ...
  <JOB
   ...
   JOBNAME="JOB1"
   ...
>
   <OUTCOND NAME="JOB1-OK" ODATE="ODAT" SIGN="ADD"/>
   <AUTOEDIT EXP="%%SYSTEM=server1"/>
  </JOB>
  <JOB
   ...
   JOBNAME="JOB2"
   ...
>
   <QUANTITATIVE NAME="DRIVE2" QUANT="1"/>
   <OUTCOND NAME="JOB2-OK" ODATE="ODAT" SIGN="ADD"/>
   <AUTOEDIT EXP="%%SYSTEM=server1"/>
  </JOB>
   ...


Second command: Add the line <QUANTITATIVE NAME="DRIVE2" QUANT="2"/> before </JOB> in all JOB entries when JOBNAME starts by JOB2. Desired output would be:
Code:
   ...
  <JOB
   ...
   JOBNAME="JOB1"
   ...
>
   <QUANTITATIVE NAME="DRIVE1" QUANT="1"/>
   <OUTCOND NAME="JOB1-OK" ODATE="ODAT" SIGN="ADD"/>
   <AUTOEDIT EXP="%%SYSTEM=server1"/>
  </JOB>
  <JOB
   ...
   JOBNAME="JOB2"
   ...
>
   <QUANTITATIVE NAME="DRIVE1" QUANT="1"/>
   <OUTCOND NAME="JOB2-OK" ODATE="ODAT" SIGN="ADD"/>
   <AUTOEDIT EXP="%%SYSTEM=server1"/>
   <QUANTITATIVE NAME="DRIVE2" QUANT="2"/>
  </JOB>
   ...

Once again thanks for for your great help! Smilie
# 7  
Old 10-14-2010
Code:
 perl -i -0pe 's/(JOBNAME="JOB1".*?)\s+<QUANTITATIVE NAME="DRIVE1" QUANT="1"\/>/\1/sg;s/(JOBNAME="JOB2".*?)(\s+<\/JOB>)/\1\n   <QUANTITATIVE NAME="DRIVE2" QUANT="2"\/>\2/gs'

This User Gave Thanks to bartus11 For This Post:
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

awk question : system output to awk variable.

Hi Experts, I am trying to get system output to capture inside awk , but not working: Please advise if this is possible : I am trying something like this but not working, the output is coming wrong: echo "" | awk '{d=system ("date") ; print "Current date is:" , d }' Thanks, (5 Replies)
Discussion started by: rveri
5 Replies

2. Homework & Coursework Questions

awk question.

Use and complete the template provided. The entire template must be completed. If you don't, your post may be deleted! 1. The problem statement, all variables and given/known data: im using ls -l | xargs | awk '{what ever files here}' im trying to get something that looks like this... (7 Replies)
Discussion started by: rontopia
7 Replies

3. UNIX for Dummies Questions & Answers

Basic awk question...getting awk to act on $1 of the command itself

I have a script problem that I am not able to solve due my very limited understanding of unix/awk. This is the contents of test.sh awk '{print $1}' From the prompt if I enter: ./test.sh Hello World I would expect to see "Hello" but all I get is a blank line. Only then if I enter "Hello... (2 Replies)
Discussion started by: JasonHamm
2 Replies

4. UNIX for Dummies Questions & Answers

awk question

Can anyone help with this this one liner: nawk -v RS='' '$1=$1' InputFile What I have in the file: 0.0013985457223116 -0.0002338180925628 0.0 0.0003709430584958 -0.0005763523138347 0.0 And the output I want: 0.0013985457223116 -0.0002338180925628 0.0 0.0003709430584958... (1 Reply)
Discussion started by: mookie123
1 Replies

5. UNIX for Dummies Questions & Answers

awk question

Hi, in the following script, what does " a=$0} END " mean ? do we need that ? Thanks awk '{a=$0} END {for (i=NR; i>=1; i--) print a}' file (3 Replies)
Discussion started by: james94538
3 Replies

6. Shell Programming and Scripting

Awk Question

How I can rid of the following presentation du -sk /u*/oradata/TEST/*.dbf |awk '{print total+=$1} 1.28003e+06 4.35109e+06 4.36134e+06 4.4535e+06 5.47752e+06 5.48777e+06 7.52554e+06 7.73036e+06 9.06158e+06 :confused: thank you (3 Replies)
Discussion started by: zam
3 Replies

7. Shell Programming and Scripting

awk question

I am trying to read through a file, gather the states in that file and change it from an abbreviation to the ful text. Can anyone provide some assistance. Thanks!! (4 Replies)
Discussion started by: cnitadesigner
4 Replies

8. Shell Programming and Scripting

awk .. question?

i have a little awk script that I use looks this: awk '{if (FNR==1){print FILENAME; print $0}else print $0}' file1...file2....fi... > bundled. i have completely forgotten how to unbundle this. I have tried several different approaches and still can not remember how to unbundle the file bundled.... (2 Replies)
Discussion started by: moxxx68
2 Replies

9. Shell Programming and Scripting

One more awk question!

Hello, I have the following command that does 2 searches. awk '{if ($0 ~ /STRING1/) {c++} }{if ( c == 2 ) {sub(/STRING1/,"NEWSTRING") } } { print }' FILE How do I search up after the first search? thanks (4 Replies)
Discussion started by: ctcuser
4 Replies

10. Shell Programming and Scripting

awk question

I have the following error: ls -lt | awk 'BEGIN NR > 1 { print $2, $9 }' Syntax Error The source line is 1. The error context is BEGIN >>> NR <<< > 1 { print $2, $9 } awk: 0602-500 Quitting The source line is 1. What I want to do is ls a directory, skip the first... (3 Replies)
Discussion started by: lesstjm
3 Replies
Login or Register to Ask a Question