awk - sub() ---> substr(), match()


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting awk - sub() ---> substr(), match()
# 1  
Old 04-22-2008
awk - sub() ---> substr(), match()

Hello guys,

I want to substitute sub() with substr() and match() for the following code. Its part of series of else if's:


Block 1)
# Example line:
# Drive sense data: f0000300 00848f0a 00000000 1100e480 008b
# This also will ignore invalid entries such as :
# Drive sense data: channel 2
# Also, if the LBA is evenly divisible by 8 (the first sector in
# a controller cache block) will print "*" if not, it will print "-"

else if (!sdata && sub(/Drive sense data: /,"") && $1 ~ /^[0-9a-f]+$/ )
{
sub (/...../,"",$1)
sub (/..$/,"",$2)
sdata=$1$2
if (substr(sdata,8,1) == 0 || substr(sdata,8,1) == 8 )
{
cach="*"
}
else cach="-"
}


Block 2)

else if (/^ detection point /)
{
# Example line:
# EEL information: recovered
# detection point 00000500 VDD_READ
# lba 0000848e
# blocks 00000056
detectpoint=1;
}
else if (detectpoint && !lba && sub(/ lba / ,""))
{
lba=$0" ";
}
else if (detectpoint && !vddRepairBlocks && sub (/ blocks / ,""))
{
vddRepairBlocks=$0" ";
}



Thanks for your help
# 2  
Old 04-23-2008
Block 1
Code:
# Drive sense data: channel 2
# Also, if the LBA is evenly divisible by 8 (the first sector in
# a controller cache block) will print "*" if not, it will print "-"

else if (!sdata && match($0, /Drive sense data:/)
{
   sub(/^Drive sense data:/, "")
   # $0 = substr($0, 1, RSTART-1) substr($0, RSTART+RLENGTH);
   if ($1 ~ /^[0-9a-f]+$/ )
   {
      $1 = substr($1, 5);
      $2 = substr($2, 1, length($2)-2);
      sdata = $1$2
      if (substr(sdata,8,1) == 0 || substr(sdata,8,1) == 8 )
      {
         cach="*"
      }
         else cach="-"
      }
   }
}

I think that keeping the sub is more readable:
Code:
else if (!sdata && /Drive sense data:/)
{
   sub(/Drive sense data:/, "")

Block 2
Code:
else if (/^ detection point /)
{
   # Example line:
   # EEL information: recovered
   # detection point 00000500 VDD_READ
   # lba 0000848e
   # blocks 00000056
   detectpoint=1;
}
else if (detectpoint && !lba && match($0, / lba /))
{
   $0  = substr($0, 1, RSTART-1) substr($0, RSTART+RLENGTH);
   lba = $0 " ";
}
else if (detectpoint && !vddRepairBlocks && match($0, / blocks /))
{
   $0  = substr($0, 1, RSTART-1) substr($0, RSTART+RLENGTH);
   vddRepairBlocks = $0 " ";
}

Jean-Pierre.
# 3  
Old 04-23-2008
Thanks much.

Worked like a charm Smilie

Last edited by DeltaX; 04-23-2008 at 03:17 PM..
# 4  
Old 04-24-2008
that $0 = substr($0, 1, RSTART-1) substr($0, RSTART+RLENGTH); wont work, I used used substr($0, x, y)


Thanks though !
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

awk and substr

Hello All; I have an input file 'abc.txt' with below text: 512345977,213458,100021 512345978,213454,100031 512345979,213452,100051 512345980,213455,100061 512345981,213456,100071 512345982,213456,100091 512345983,213457,100041 512345984,213451,100011 I need to paste the first field... (10 Replies)
Discussion started by: mystition
10 Replies

2. Shell Programming and Scripting

HELP : awk substr

Hi, - In a file test.wmi Col1 | firstName | lastName 4003 | toto_titi_CT- | otot_itit - I want to have only ( colones $7,$13 and $15) with code 4003 and 4002. for colone $13 I want to have the whole name untill _CT- or _GC- 1- I used the command egrep with awk #egrep -i... (2 Replies)
Discussion started by: georg2014
2 Replies

3. Shell Programming and Scripting

awk substr

Hello life savers!! Is there any way to use substr in awk command for returning one part of a string from declared start and stop point? I mean I know we have this: substr(string, start, length) Do we have anything like possible to use in awk ? : substr(string, start, stop) ... (9 Replies)
Discussion started by: @man
9 Replies

4. Shell Programming and Scripting

Substr with awk

Hi to all, I'm here again, cause I need your help to solve another issue for me. I have some files that have this name format: date_filename.csv In my shell I must rename each file removing the date so that the file name is filename.csv To do this I use this command: fnames=`ls ${fname}|... (2 Replies)
Discussion started by: leobdj
2 Replies

5. Shell Programming and Scripting

awk substr

HI I am using awk and substr function to list out the directory names in the present working directory . I am using below code ls -l | awk '{ if ((substr($1,1,1)) -eq d) {print $9 }}' But the problem is i am getting all the files and directories listed where as the requirement i wrote... (7 Replies)
Discussion started by: prabhu_kumar
7 Replies

6. Shell Programming and Scripting

Help with awk and substr

I have the following to find lines matching "COMPLETE" and extract parts of it using substr. sed -n "/COMPLETE/p" 1.txt | awk 'BEGIN { FS = "\" } {printf"%s %s:%s \n", substr($3,17,3),substr($6,4,1), substr($7,4,1)}' | sort | uniq > temp.txt Worked fine until the numbers in 2nd & 3rd substr... (5 Replies)
Discussion started by: zpn
5 Replies

7. Shell Programming and Scripting

awk substr

Hi I have multiple files that name begins bidb_yyyymm. (yyyymm = current year month of file creation). What I want to do is look at the files and where yyyymm is older than 1 month I want to remove the file from the server. I was looking at looping through the files and getting the yyyymm... (2 Replies)
Discussion started by: colesga
2 Replies

8. UNIX for Dummies Questions & Answers

awk or substr

i have a variable 200612 the last two digits of this variable should be between 1 and 12, it should not be greater than 12 or less than 1 (for ex: 00 or 13,14,15 is not accepted) how do i check for this conditions in a unix shell script. thanks Ram (3 Replies)
Discussion started by: ramky79
3 Replies

9. Shell Programming and Scripting

How to use awk substr ?

Hi all, I have a flatfile I would like to get ext = 7950 , how do I do that ? if ($1 == "CTI-ProgramStart") { ext = substr($9,index($9,"Extension")+11,4); But why it is not working ???? Please help . Thanks (1 Reply)
Discussion started by: sabercats
1 Replies

10. Shell Programming and Scripting

awk substr?

Sorry if this has been posted before, I searched but not sure what I really want to do. I have a file with records that show who has logged into my application: 2003-03-14:I:root: Log_mesg: registered servername:userid. (more after this) I want to pull out the userid, date and time into... (2 Replies)
Discussion started by: MizzGail
2 Replies
Login or Register to Ask a Question