Need help on find and replacement on specific line and position


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting Need help on find and replacement on specific line and position
# 22  
Old 01-16-2014
Some example might help you to understand

Code:
# Replace 3rd char with star
$ echo "1234567890" | awk -F "" '{gsub(".","*",$3)}1' OFS=""
12*4567890

# Replace 5th char onwards with some string
$ echo "1234567890" | awk  '{$0=substr($0,1,5) New}1' New="tester"
12345tester

Read below one

substr(string, start, length)This returns a length-character-long substring of string, starting at character number start. The first character of a string is character number one.

Example:
substr("washington", 5, 3) returns "ing". If length is not present, this function returns the whole suffix of string that begins at character number start.

substr("washington", 5) returns "ington". This is also the case if length is greater than the number of characters remaining in the string, counting from character number start.
# 23  
Old 01-16-2014
Quote:
Originally Posted by Akshay Hegde
Some example might help you to understand

Code:
# Replace 3rd char with star
$ echo "1234567890" | awk -F "" '{gsub(".","*",$3)}1' OFS=""
12*4567890

# Replace 5th char onwards with some string
$ echo "1234567890" | awk  '{$0=substr($0,1,5) New}1' New="tester"
12345tester

... ... ...
Note that the standards say that the results are unspecified if an empty string is assigned to FS. Some versions of awk will produce the output you showed above in your first example. The version of awk on OS/X issues the warning and output:
Code:
awk: field separator FS is empty

1234567890

A better example might be:
Code:
echo "1234567890" | awk '{print substr($0,1,2)"*"substr($0,4)}'

which should produce the output:
Code:
12*4567890

with any version of awk that conforms to the standards.

And, in your 2nd example, the comment says you're replacing the 5th character, but the substr() is copying the 1st five characters unchanged.
This User Gave Thanks to Don Cragun For This Post:
# 24  
Old 01-17-2014
Don I don't know about the OS/X, and in second example I mean to say retain 1st five char and 5th char onwards to length of line replace with some string, Sorry for bad English
This User Gave Thanks to Akshay Hegde For This Post:
# 25  
Old 01-17-2014
Quote:
Originally Posted by Akshay Hegde
Don I don't know about the OS/X, and in second example I mean to say retain 1st five char and 5th char onwards to length of line replace with some string, Sorry for bad English
I'm not concerned about your English. You are much better at English than I am in your native language! (When I attended college, I was allowed to use proficiency in FORTRAN and CDC assembler to meet MSU's requirement to understand a foreign language.)

I only mentioned the -F "" issue because the O/S being used by the submitter of this thread was never specified. The code you gave will work fine with gawk (or awk on a Linux system), but it is not portable to other systems since the standards explicitly state that the results are unspecified in this case. (OS/X is just one example of a system where an empty string is not accepted by awk as a field separator.)
This User Gave Thanks to Don Cragun For This Post:
# 26  
Old 01-17-2014
@ Don

You are right as always ! I tested it on GNU Awk 3.1.7, without warnings it worked there.
This User Gave Thanks to Akshay Hegde For This Post:
# 27  
Old 01-29-2014
Quote:
Originally Posted by Don Cragun
So there were two off by one errors. Also change:
Code:
      for(i=1;i<length(F);i++)N[substr(F,i,1)]=substr(T,i,1);

to:
Code:
      for(i=1;i<=length(F);i++)N[substr(F,i,1)]=substr(T,i,1);

Code:
awk  -v k3="$k3" '
    BEGIN{
      F="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"
      T="ZYXWVUTSRQPONMLKJIHGFEDCBAzyxwvutsrqponmlkjihgfedcba9876543210"
      for(i=1;i<=length(F);i++)N[substr(F,i,1)]=substr(T,i,1);
    }
    NR == k3 {
      out=x
      for(i=1;i<=length;i++) {
         c=substr($0,i,1)
         out=out (i>9&&(c in N)?N[c]:c)
      }
      $0=out
    }
    1
' $file

i don't have any issue with the above code. is it possible to make the above code work on single field .. say field $3 .. first it has to search a specific field ($3) . in field # 3, it has to replace from 9 th posotion to end of line
# 28  
Old 01-29-2014
This should match on field three, notice how if matching the "*" (star) character two backquotes are needed.

The star on the end is to match with the rest of the string so example is looking for any field 3 that starts with "NM1*IL*1"

Code:
k3='NM1\\*IL\\*1*'
awk -v k3="$k3" '
    BEGIN{
      F="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"
      T="ZYXWVUTSRQPONMLKJIHGFEDCBAzyxwvutsrqponmlkjihgfedcba9876543210"
      for(i=1;i<=length(F);i++)N[substr(F,i,1)]=substr(T,i,1);
    }
    $3 ~ k3 {
      out=x
      for(i=1;i<=length($3);i++) {
         c=substr($3,i,1)
         out=out (i>9&&(c in N)?N[c]:c)
      }
      $3=out
    }
    1
' $file

This User Gave Thanks to Chubler_XL 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

Count specific character of a file in each line and delete this character in a specific position

I will appreciate if you help me here in this script in Solaris Enviroment. Scenario: i have 2 files : 1) /tmp/TRANSACTIONS_DAILY_20180730.txt: 201807300000000004 201807300000000005 201807300000000006 201807300000000007 201807300000000008 2)... (10 Replies)
Discussion started by: teokon90
10 Replies

2. Shell Programming and Scripting

Remove line break at specific position

Hi, I need to remove line breaks from a file, but only the ones at specific position. Input file: this is ok this line is divided at posit ion 30. The same as this one, also position 30 the rest of lines are ok with different lengths The longest ones are always s plitted at same... (15 Replies)
Discussion started by: qranumo
15 Replies

3. Shell Programming and Scripting

Find and replace with 0 for characters in a specific position

Need command for position based replace: I need a command to replace with 0 for characters in the positions 11 to 20 to all the lines starts with 6 in a file. For example the file ABC.txt has: abcdefghijklmnopqrstuvwxyz 6abcdefghijklmnopqrstuvwxyz abcdefghijklmnopqrstuvwxyz... (4 Replies)
Discussion started by: thangabalu
4 Replies

4. Shell Programming and Scripting

How to concatene files and put each line of files on a specific position ?

Hi, I have some files that i want to concatene and put each of lines of this files on a specific position : File1 AAAAAAA BBBBBBB CCCCCCC File2 DDDDDDD EEEEEEE FFFFFFF File3 GGGGGG HHHHHH IIIIII New file (6 Replies)
Discussion started by: apippo70
6 Replies

5. Shell Programming and Scripting

Printing characters at specific position in line

Hi, I am trying to get an output like : +----------------------------------+ ----------- + + some variable substitution + some text + Is there a way I can specify in printf (in ksh) the particular position I want to print a character, and also repeat a character from... (1 Reply)
Discussion started by: neil.k
1 Replies

6. Shell Programming and Scripting

Find the position of a pattern on a line from a csv file

hello I'm doing a unix program and i'm using many file csv.in each csv file the colums are separated by ";" I would like to know the position of a pattern. For example for a line yyyy, bbbb, cccc; ddddd;eeee. I will like for example by finding the position of the pattern "cccc" and the response is... (6 Replies)
Discussion started by: papis
6 Replies

7. Shell Programming and Scripting

Search in specific position and print the whole line

I have two files abc.dat and sant.dat (Big file 60k rows) for every line's 1,4 of abc.dat need to seach if this is present on 28,4 of sant.dat every line. if its present the output needs to go to bde.dat Example: contents abc.dat aaaa bbbb cccc dddd contents sant.dat this is... (4 Replies)
Discussion started by: ssantoshss
4 Replies

8. Shell Programming and Scripting

search a line and insert string into specific at position

Hi, guys. I have one question: How can I search for a line with certain string in it and then insert a string into this line? For example: There is a file called shadow, the contents of it are below: ************************** ... yuanz:VIRADxMsadfDF/Q:0:0:50:7:::... (9 Replies)
Discussion started by: daikeyang
9 Replies

9. Shell Programming and Scripting

Deleting Characters at specific position in a line if the line is certain length

I've got a file that would have lines similar to: 12345678 x.00 xx.00 x.00 xxx.00 xx.00 xx.00 xx.00 23456781 x.00 xx.00 xx.00 xx.00 xx.00 x.00 xxx.00 xx.00 xx.00 xx.00 34567812 x.00 xx.00 x.00 xxx.00 xx.00 xx.00 xx.00 45678123 x.00 xx.00 xx.00 xx.00 xx.00 x.00 xxx.00 xx.00 xx.00 xx.00 xx.00... (10 Replies)
Discussion started by: Cailet
10 Replies

10. Shell Programming and Scripting

check position of end of line for some specific lines

-------------------------------------------------------------------------------- Have to check in a file that the lines starting with 620 and 705 are ending at same posiotin. 82012345 62023232323 70523949558 62023255454 9999 In the above lines, i have to check the lines starting... (1 Reply)
Discussion started by: senthil_is
1 Replies
Login or Register to Ask a Question