Sponsored Content
Top Forums Shell Programming and Scripting Extracting words and lines based on keywords Post 302818875 by Yoda on Sunday 9th of June 2013 05:14:56 PM
Old 06-09-2013
AWK approach based on some assumptions

To print word before world:
Code:
awk '
        /world/ {
                n = match ( $0, /[^ ]*[ -]*world/ )
                s = substr ( $0, n, RLENGTH - 5 )
                sub ( /[ -]/, X, s )
                print s
        }
' file

To print paragraph after design:
Code:
awk '
        /design/ {
                f = 1
                next
        }
        f && NF {
                print $0
                exit
}'  file

 

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

Search and replace words between two keywords

Hi, I have a file which contains the following : select * from test where test_id=1; select id from test1, test2 where test_id=1 and test_id=2; select * from test1, test2, test3 where test_id=4 and test2_id where in (select test2_id from test2); select id1, id2 from test ... (6 Replies)
Discussion started by: vrrajeeb
6 Replies

2. Shell Programming and Scripting

Capture lines based on keywords

Hello everyone, I am trying to write a script that will capture few lines from a text file based on 2 keywords in the first line and 1 keyword in the last one. It could also be based on the first line only + the folllowing 3 lines. Could some one help or give directions. Thanks. (4 Replies)
Discussion started by: nimo
4 Replies

3. Shell Programming and Scripting

Extracting lines in file based on time

Hi, anyone has any ideas on how do we extract lines from a file with format similiar to this: (based on current time) Jun 18 00:16:50 .......... ............. ............ Jun 18 00:17:59 .......... ............. ............ Jun 18 01:17:20 .......... ............. ............ Jun 18... (5 Replies)
Discussion started by: faelric
5 Replies

4. Shell Programming and Scripting

awk : extracting unique lines based on columns

Hi, snp.txt CHR_A SNP_A BP_A_st BP_A_End CHR_B BP_B SNP_B R2 p-SNP_A p-SNP_B 5 rs1988728 74904317 74904318 5 74960646 rs1427924 0.377333 0.000740085 0.013930081 5 ... (12 Replies)
Discussion started by: genehunter
12 Replies

5. Shell Programming and Scripting

Extracting specific lines of data from a file and related lines of data based on a grep value range?

Hi, I have one file, say file 1, that has data like below where 19900107 is the date, 19900107 12 144 129 0.7380047 19900108 12 168 129 0.3149017 19900109 12 192 129 3.2766666E-02 ... (3 Replies)
Discussion started by: Wynner
3 Replies

6. Shell Programming and Scripting

Extracting few lines from a file based on identifiers dynamically

i have something like this in a file called mysqldump.sql -- -- Table structure for table `Table11` -- DROP TABLE IF EXISTS `Table11`; /*!40101 SET @saved_cs_client = @@character_set_client */; /*!40101 SET character_set_client = utf8 */; CREATE TABLE `Table11` ( `id` int(11) NOT NULL... (14 Replies)
Discussion started by: vivek d r
14 Replies

7. Shell Programming and Scripting

Extracting lines based on identifiers into multiple files respectively

consider the following is the contents of the file cat 11.sql drop procedure if exists hoop1 ; Delimiter $$ CREATE PROCEDURE hoop1(id int) BEGIN END $$ Delimiter ; . . . . drop procedure if exists hoop2; Delimiter $$ CREATE PROCEDURE hoop2(id int) BEGIN END $$ (8 Replies)
Discussion started by: vivek d r
8 Replies

8. Shell Programming and Scripting

Sorting lines based on keywords for MySQL script

the thing which i require is very very complex.. i tried hard to find the solution but couldnt.. the thing i need to achieve is say i have a file cat delta.sql CREATE VIEW Austin Etc etc . . . CREATE VIEW Barabara AS SELECT blah blah blah FROM Austin z, Cluster s, Instance i WHERE... (4 Replies)
Discussion started by: vivek d r
4 Replies

9. Shell Programming and Scripting

copy range of lines in a file based on keywords from another file

Hi Guys, I have the following problem. I have original file (org.txt) that looks like this module v_1(.....) //arbitrary number of text lines endmodule module v_2(....) //arbitrary number of text lines endmodule module v_3(...) //arbitrary number of text lines endmodule module... (6 Replies)
Discussion started by: kaaliakahn
6 Replies

10. Shell Programming and Scripting

extracting lines based on condition and copy to another file

hi i have an input file that contains some thing like this aaa acc aa abc1 1232 aaa abc2.... poo awq aa abc1 aaa aaa abc2 bbb bcc bb abc1 3214 bbb abc3.... bab bbc bz abc1 3214 bbb abc3.... vvv ssa as abc1 o09 aaa abc4.... azx aaq aa abc1 900 aqq abc19.... aaa aa aaaa abc1 899 aa... (8 Replies)
Discussion started by: anurupa777
8 Replies
vc(1)							      General Commands Manual							     vc(1)

Name
       vc - version control program

Syntax
       vc [-a] [-t] [-cchar] [-s] [keyword=value... keyword=value]

Description
       The  command  copies lines from the standard input to the standard output under control of its arguments and control statements encountered
       in the standard input.  In the process of performing the copy operation, user declared keywords may be replaced by their string value  when
       they appear in plain text and/or control statements.

       The  copying  of  lines from the standard input to standard output is conditional.  It is based on tests (in control statements) of keyword
       values specified in control statements or as command arguments.

       A control statement is a single line beginning with a control character, except as modified by the -t keyletter (see below).   The  default
       control character is colon (:), except as modified by the -c keyletter (see below).  Input lines beginning with a backslash () followed by
       a control character are not control lines and are copied to the standard output with the backslash removed.  Lines beginning with  a  back-
       slash followed by a noncontrol character are copied in their entirety.

       A  keyword  is  composed of 9 or fewer alphanumerics; the first must be alphabetic.  A value is any ASCII string that can be created with A
       numeric value is an unsigned string of digits.  Keyword values should contain blanks or tabs.

       Replacement of keywords by values occurs whenever a keyword surrounded by control characters is encountered on a version control statement.
       The  -a keyletter (see below) forces replacement of keywords in all lines of text.  An uninterpreted control character may be included in a
       value by preceding it with .  If a literal  is desired, then it too must be preceded by .

Options
       Keyletter arguments:

       -a Replaces the keywords surrounded by control characters in all text lines.

       -cchar
	  Specifies a control character to be used in place of :.

       -s Suppresses all warning messages.

       -t Ignores all characters from the beginning of the line to the first tab character.  If one is found, all characters up to  and  including
	  the tab are discarded.

Version Control Statements:
       :dcl  keyword[, ..., keyword]
	    Used to declare keywords.  All keywords must be declared.

       :asg keyword=value
	    Used  to  assign  values to keywords.  An asg statement overrides the assignment for the corresponding keyword on the command line and
	    all previous asg's for that keyword.  Keywords declared, but not assigned values have null values.

       :if condition
	    .
	    .
	    .
       :end
	    Used to skip lines of the standard input. If the condition is true all lines between the if statement and the matching  end  statement
	    are  copied  to  the  standard  output.  If the condition is false, all intervening lines are discarded, including control statements.
	    Note that intervening if statements and matching end statements are recognized solely for the purpose of maintaining the proper if-end
	    matching.
	    The syntax of a condition is:

	     <cond>  ::= [ "not" ] <or>
	     <or>    ::= <and> | <and> "|" <or>
	     <and>   ::= <exp> | <exp> "&" <and>
	     <exp>   ::= "(" <or> ")" | <value> <op> <value>
	     <op>    ::= "=" | "!=" | "<" | ">"
	     <value> ::= <arbitrary ASCII string> | <numeric string>

	    The available operators and their meanings are:

	       =      equal
	       !=     not equal
	       &      and
	       |      or
	       >      greater than
	       <      less than
	       ( )    used for logical groupings
	       not    may only occur immediately after the if, and
		      when present, inverts the value of the
		      entire condition

	    The  >  and  < operate only on unsigned integer values.  For example, : 012 > 12 is false).  All other operators take strings as argu-
	    ments.  For example, fB: 012 != 12 is true).  The precedence of the operators (from highest to lowest) is:
	       = != > <      all of equal precedence
	       &
	       |
	    Parentheses can be used to alter the order of precedence.
	    Values must be separated from operators or parentheses by at least one blank or tab.

       ::text
	    Used for keyword replacement on lines that are copied to the standard output.  The two leading control  characters	are  removed,  and
	    keywords  surrounded  by  control  characters  in text are replaced by their value before the line is copied to the output file.  This
	    action is independent of the -a keyletter.

       :on

       :off
	    Turn on or off keyword replacement on all lines.

       :ctl char
	    Change the control character to char.

       :msg message
	    Prints the given message on the diagnostic output.

       :err message
	    Prints the given message followed by:
		 ERROR: err statement on line ... (915)
	    on the diagnostic output.  The command halts execution, and returns an exit code of 1.

Diagnostics
       Use for explanations.

Exit Codes
       0 - normal
       1 - any error

																	     vc(1)
All times are GMT -4. The time now is 09:19 PM.
Unix & Linux Forums Content Copyright 1993-2022. All Rights Reserved.
Privacy Policy