Replace a multi-line strings or numbers


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting Replace a multi-line strings or numbers
# 15  
Old 05-24-2013
You can code something like:
Code:
SEQ=200
awk -v S="$SEQ" '
        {
                A[++c] = $1
        }
        END {
                for ( i = 1; i <= c; i++ )
                {
                        if ( A[i] == S )
                        {
                                C[A[i],A[i+1],A[i-1]]++
                                V[A[i],A[i+1],A[i-1]] = "the letter is " A[i] RS "followed by " A[i+1] RS "comes after " A[i-1]
                        }
                }
                for ( k in V )
                {
                        print C[k] " times"
                        print V[k]
                }
        }
' file

This User Gave Thanks to Yoda For This Post:
# 16  
Old 05-24-2013
Thanks Yoda

You are awesome!

how I can sort the output descending ?

Thanks
# 17  
Old 05-24-2013
Quote:
Originally Posted by khaled79
how I can sort the output descending?
By default, the order in which a for (i in array) loop scans an array is not defined; it is generally based upon the internal implementation of arrays inside awk.

So you have to use an Indexed Array to help preserve the order, try this modified code:
Code:
SEQ=200
awk -v S="$SEQ" '
        {
                A[++c] = $1
        }
        END {
                for ( i = 1; i <= c; i++ )
                {
                        if ( A[i] == S )
                        {
                                if ( !(V[A[i] A[i+1] A[i-1]]) )
                                        T[++j] = A[i] A[i+1] A[i-1]
                                C[A[i] A[i+1] A[i-1]]++
                                V[A[i] A[i+1] A[i-1]] = "the letter is " A[i] RS "followed by " A[i+1] RS "comes after " A[i-1]
                        }
                }
                for ( i = 1; i <= j; i++ )
                {
                        print C[T[i]] " times"
                        print V[T[i]]
                }
        }
' file

# 18  
Old 05-24-2013
The result wasn't ordered descending based on times

Code:
 
25 times
the letter is 200
followed by 202
comes after 211
36 times
the letter is 200
followed by 223
comes after 212

it should print the 36 times result followed by 25 result

Thanks
# 19  
Old 05-24-2013
I'm sorry. I misread your requirement. I thought you want to print records in the order that you have them in your input file.

If you have gawk then you can use below code to print in descending order:
Code:
SEQ=200
gawk -v S="$SEQ" '
        {
                A[++c] = $1
        }
        END {
                for ( i = 1; i <= c; i++ )
                {
                        if ( A[i] == S )
                        {
                                C[A[i],A[i+1],A[i-1]]++
                                V[A[i],A[i+1],A[i-1]] = "the letter is " A[i] RS "followed by " A[i+1] RS "comes after " A[i-1]
                        }
                }
                for ( k in V )
                {
                        T[++j] = C[k]
                }
                n = asort(T)
                for ( i = n; i >= 1; i-- )
                {
                        for ( k in V )
                        {
                                if ( C[k] == T[i] )
                                {
                                        print C[k] " times"
                                        print V[k]
                                }
                        }
                }
        }
' file

This User Gave Thanks to Yoda For This Post:
# 20  
Old 05-24-2013
Thanks Yoda
Suppose that I have texts in different languages

how I could print the frequent n words

like frequent 10 or 100 ?

It is easy to do it for A-Z which is English

but, regardless the input language text how I can do it?



Thanks
# 21  
Old 05-27-2013
Suppose that I have file in the following format

Code:
 
199
300
225
222
250
202
400
205
207

and I want to change
Code:
300 and 250 and 205

to
Code:
260

and save it to file A.

Then I need to make every 260 in the file A back to the original values which is

Code:
 
300 and 250 and 205


how I could do that

Thanks
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

Multi line regex for search and replace

I have text file like below: a.txt Server=abc Run=1 Time=120.123 Tables=10 Sessions=16 Time=380.123 Version=1.1 Jobs=5 Server=abc Run=2 Time=160.123 Tables=15 Sessions=16 Time=400.258 Version=2.0 (1 Reply)
Discussion started by: sol_nov
1 Replies

2. Homework & Coursework Questions

[solved]Perl: Printing line numbers to matched strings and hashes.

Florida State University, Tallahassee, FL, USA, Dr. Whalley, COP4342 Unix Tools. This program takes much of my previous assignment but adds the functionality of printing the concatenated line numbers found within the input. Sample input from <> operator: Hello World This is hello a sample... (2 Replies)
Discussion started by: D2K
2 Replies

3. Shell Programming and Scripting

sed to replace a line with multi lines from a var

I am trying to find a line in a file ("Replace_Flag") and replace it with a variable which hold a multi lined file. myVar=`cat myfile` sed -e 's/Replace_Flag/'$myVar'/' /pathto/test.file myfile: cat dog boy girl mouse house test.file: football hockey Replace_Flag baseball ... (4 Replies)
Discussion started by: bblondin
4 Replies

4. Shell Programming and Scripting

SED - insert space at the beginning of line and multi replace command

hi I am trying to use SED to replace the line matching a pattern using the command sed 'pattern c\ new line ' <file1 >file 2 I got two questions 1. how do I insert a blank space at the beginning of new line? 2. how do I use this command to execute multiple command using the -e... (5 Replies)
Discussion started by: piynik
5 Replies

5. Shell Programming and Scripting

Multi-line filtering based on multi-line pattern in a file

I have a file with data records separated by multiple equals signs, as below. ========== RECORD 1 ========== RECORD 2 DATA LINE ========== RECORD 3 ========== RECORD 4 DATA LINE ========== RECORD 5 DATA LINE ========== I need to filter out all data from this file where the... (2 Replies)
Discussion started by: Finja
2 Replies

6. Shell Programming and Scripting

Search for a multi-line strings in a file

Hello I need to search for a mult-line strngs(with spaces in between and qoted) in a file1 and replace that text with Fixed string globally in file1. The strng to search for is in file2. The file is big with some 20K records. so speed and effciency is required file1: (where srch & rplc will... (7 Replies)
Discussion started by: Hiano
7 Replies

7. Shell Programming and Scripting

Global search and replace multi line file

Hello I need to search for a mult-line strngs(with spaces in between and qoted) in a file1 and replace that text with Fixed string globally in file1. The strng to search for is in file2. The file is big with some 20K records. so speed and effciency is required file1: (where srch & rplc... (0 Replies)
Discussion started by: Hiano
0 Replies

8. Shell Programming and Scripting

Multi-Line Search and Replace

There appears to be several threads that touch on what I'm trying to do, but nothing quite generic enough. What I need to do is search through many (poorly coded) HTML files and make changes. The catch is that my search string may be on one line or may be on several lines. For example there... (5 Replies)
Discussion started by: bisbell
5 Replies

9. Shell Programming and Scripting

multi line multirecord find and replace

Hello I am looking to have a script that performs some tasks for find and replace and inserts a line as well. I have done some programming 10 years ago, so it is causing me a little grief. File consists of 2500 records. I will show you a sample consisting of two records below and what needs... (3 Replies)
Discussion started by: cdc01
3 Replies

10. Shell Programming and Scripting

Search and replace multi-line text in files

Hello I need to search for a mult-line text in a file exfile1 and replace that text with another text. The text to search for is in exfile2 and the replacement text is in exfile3. I work with kornshell under AIX and need to do this with a lot of files. (the file type is postscript and they need... (10 Replies)
Discussion started by: marz
10 Replies
Login or Register to Ask a Question