need a logic for awk programming


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting need a logic for awk programming
# 1  
Old 01-22-2008
Data need a logic for awk programming

Hello Friends,

I have a txt file like below
Code:
//*Init Start
Reg(read,12'h42E,16'h0000);
Nop(5628.5);
//*Init End

//*Main Start
Reg(read,12'h42E,16'h0000);
Nop(5628.5);
//*Main End

I want to calculate the values between //* Init Start & //* Init End
And //*Main Start & //*Main End.
But in a single awk programme I need to process separately for Init Block and Main Block.

Means when it founds Init start it should be in a loop until it founds Init End and when it founds Main start it should be in a loop until it founds Main End .

Please need help .. Thank you in advance..
# 2  
Old 01-22-2008
what's the code you have?
# 3  
Old 01-22-2008
Quote:
Originally Posted by ghostdog74
what's the code you have?
Code:
gawk '
 
BEGIN{
}
/\/\/\*Main Start/ {
       while( $0 !~ "\/\/\*Main End"){
       print "Inside Main " $0
       next
       }
  }
/\/\/\*Init Start/ {
       while( $0 ~! "...Init End"){
       print "Inside Init " $0
       next
       }
  }
' myfile

but it shows me error when I use gawk
gawk: cmd. line:10: warning: escape sequence `\/' treated as plain `/'
gawk: cmd. line:10: warning: escape sequence `\*' treated as plain `*'

and in nawk no output..

I want to do something like this
Code:
/\/\/\*Init Start/ {
       print "Inside Init " $0
       while(getline ){
               if ($0 !~ /\/\/\*Init End/){
                       print $0
               }
       }
  }

But not working what exactly I want..
I want to print all those lines Inside Init Start And Init End and nothing else

Last edited by user_prady; 01-22-2008 at 03:45 AM..
# 4  
Old 01-22-2008
to display text between 2 patterns,
Code:
awk '
/Init Start/ , /Init End/  {
    print $0
}' "file"

do the same for "main"
# 5  
Old 01-22-2008
Quote:
Originally Posted by user_prady
Code:
gawk '
 
BEGIN{
}
/\/\/\*Main Start/ {
       while( $0 !~ "\/\/\*Main End"){
       print "Inside Main " $0
       next
       }
  }
/\/\/\*Init Start/ {
       while( $0 ~! "...Init End"){
       print "Inside Init " $0
       next
       }
  }
' myfile

but it shows me error when I use gawk
gawk: cmd. line:10: warning: escape sequence `\/' treated as plain `/'
gawk: cmd. line:10: warning: escape sequence `\*' treated as plain `*'

and in nawk no output..

I want to do something like this
Code:
/\/\/\*Init Start/ {
       print "Inside Init " $0
       while(getline ){
               if ($0 !~ /\/\/\*Init End/){
                       print $0
               }
       }
  }

But not working what exactly I want..
I want to print all those lines Inside Init Start And Init End and nothing else
Yes now I am getting what I want
Code:
/\/\/\*Init Start/ {
       print "Inside Init " $0
               while ($0 !~ /\/\/\*Init End/){
                       getline;
                       print $0
               }
  }

# 6  
Old 01-23-2008
You can try like this :

Instead of writng to file, you can put the logic you want.

Code:
awk '/Init Start/,/Init End/{print $0>"init_file"} /Main Start/,/Main End/{print $0>"main_file";}' filename


Output:
Quote:
main_file

Quote:
//*Main Start
Reg(read,12'h42E,16'h0000);
Nop(5628.5);
//*Main End

Init_file

Quote:
//*Init Start
Reg(read,12'h42E,16'h0000);
Nop(5628.5);
//*Init End
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

More a logic than a programming question

hello, I'm a littlebit lost... i have a table of single names and combination of two names and i want a table of ALL single names with ALL combinations (also the indirect ones). - - - in reality the names are longer, not only a,b,.. and the table is tab-delimited, and the result table... (6 Replies)
Discussion started by: dietmar13
6 Replies

2. Shell Programming and Scripting

awk logic

I am trying to check my logic on a long awk i'm using. I have about 30 checks that I built into an awk and I "believe" I did this right, but I could be wrong. awk -F\| ' $9 !~ /\/*{1,}*/ $9 ~ /\(-{4}, {2,3}/ $9 ~ /\({6}, {2,3}\)/ $9 ~ /\(\+{5}, {2,3}\)/ $9 ~ /\(\+\+{4}, {2,3}\)/ $9 ~... (8 Replies)
Discussion started by: dagamier
8 Replies

3. Shell Programming and Scripting

Programming logic help

Hi, I was having a problem regarding this thread: https://www.unix.com/shell-programming-scripting/225221-setting-variable-using-variables-loop.html I have not been able to solve that issue. So i was thinking maybe my logic to solve the overall problem is wrong, so i am looking for a bit of... (2 Replies)
Discussion started by: brunlea
2 Replies

4. Shell Programming and Scripting

How to use this logic with awk?

Hi friends, I am having 2 files, I just want to compare 2 files each containing 2 columns 1st column is lat, and 2nd column is long, if anyone can understand below logic please help me in writing script with awk.. here each field of file2 needs to be compared with std_file main counter=0... (1 Reply)
Discussion started by: Akshay Hegde
1 Replies

5. UNIX for Dummies Questions & Answers

awk logic and math help

Hi, My file has 2 fields and millions of lines. variableStep chrom=Uextra span=25 201 0.5952 226 0.330693 251 0.121004 276 0.0736858 301 0.0646982 326 0.0736858 401 0.2952 426 0.230693 451 0.221004 476 0.2736858 Each field either has a... (6 Replies)
Discussion started by: wyarosh
6 Replies

6. UNIX for Dummies Questions & Answers

Need help in logic using awk command

I have task to find out the min,max, average value of each service for example i searched for " StatementService " $awk '/VST.*StatementService:/{print $3,$4,$19,$22,$25}' performance.log > smp.log $cat smp.log amexgtv VST: : StatementService:1860 StatementService:getCardReference:0... (3 Replies)
Discussion started by: senthil.ak
3 Replies

7. Shell Programming and Scripting

need an awk script/logic

In one data file i have values like this a b c 1 2 e f g 2 3 i j k 3 5 I need to sum up the last 2 columns and make a data file...How i can do that. a b c 1 2 e f g 2 3 i j k 3 5... (8 Replies)
Discussion started by: bobprabhu
8 Replies

8. Shell Programming and Scripting

Help with awk logic

I want to print lines that have "IND" or "ind" or nothing in field 2 or 3 file: output needed: Code i wrote: nawk -F"," '{if(tolower($2||$3) ~"ind"||"")print}' file Help is appreciated (3 Replies)
Discussion started by: pinnacle
3 Replies

9. Shell Programming and Scripting

need a logic to start with awk/ sh

Hi Friends, I got stuck where to start with .. I ve a input file like below. where I want to compare write data with my read data .. The problem is that the read data should be compared with the lastest write data on that address. Note- Both write data & read data are in the same... (8 Replies)
Discussion started by: user_prady
8 Replies

10. Shell Programming and Scripting

cannot get logic for concatenation awk

Hello friends, I have a problem in printing an array.. Example if my array line contains 4 elements like following line=0002 , line=202200, line=200002, line= 300313 Now one = sprintf line line line line will concatenate my whole array to one. But I am not sure about the... (7 Replies)
Discussion started by: user_prady
7 Replies
Login or Register to Ask a Question