Sponsored Content
Top Forums Shell Programming and Scripting search string in a file and retrieve 10 lines including string line Post 302446176 by ranjithpr on Wednesday 18th of August 2010 02:59:41 AM
Old 08-18-2010
Hope this is what you were expecting

Code:
$ cat 1.txt
word1 line1 word2
word1 line2 word2
word1 line3 word2
word1 line4 word2
word1 "line5" word2
word1 line6 word2
word1 line7 word2
word1 "line5" word2
word1 line8 word2
word1 line9 word2
$ awk '/\"line5\"/ {for(i=0;i<4;i++) {print;if(!getline) exit;} }' 1.txt > result.txt
$ cat result.txt
word1 "line5" word2
word1 line6 word2
word1 line7 word2
word1 "line5" word2
$

 

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

Retrieve string from each line in a file based on a pattern in Unix

I have a file which contains several lines. Sample content of the file is as below. OK testmessage email<test@123> NOK receivemessage email<123@test> NOK receivemessage email(123@test123) NOK receivemessage email<abc@test> i would like to know by scripting will... (10 Replies)
Discussion started by: ramasar
10 Replies

2. Shell Programming and Scripting

replace (sed?) a single line/string in file with multiple lines (string) from another file??

Can someone tell me how I can do this? e.g: Say file1.txt contains: today is monday the 22 of NOVEMBER 2010 and file2.txt contains: the 11th month of How do i replace the word NOVEMBER with (5 Replies)
Discussion started by: tuathan
5 Replies

3. Shell Programming and Scripting

Grep a string from input file and delete next three lines including the line contains string in xml

Hi, 1_strings file contains $ cat 1_strings /home/$USER/Src /home/Valid /home/Review$ cat myxml <projected value="some string" path="/home/$USER/Src"> <input 1/> <estimate value/> <somestring/> </projected> <few more lines > <projected value="some string" path="/home/$USER/check">... (4 Replies)
Discussion started by: greet_sed
4 Replies

4. Shell Programming and Scripting

Search string and print the above line and below lines?.

if the first string matches then print the previous line and current line and also print the following lines if the other string search matches. Input ------ TranTime 2012 10 12 The Record starts here Accountnumber: 4632473431274 TxnCode 323 TranID 329473242834 ccsdkcnsdncskd... (7 Replies)
Discussion started by: laknar
7 Replies

5. Shell Programming and Scripting

Search several string and convert into a single line for each search string using awk command AIX?.

I need to search the file using strings "Request Type" , " Request Method" , "Response Type" and by using result set find the xml tags and convert into a single line?. below are the scenarios. Cat test Nov 10, 2012 5:17:53 AM INFO: Request Type Line 1.... (5 Replies)
Discussion started by: laknar
5 Replies

6. Shell Programming and Scripting

Remove lines between the start string and end string including start and end string Python

Hi, I am trying to remove lines once a string is found till another string is found including the start string and end string. I want to basically grab all the lines starting with color (closing bracket). PS: The line after the closing bracket for color could be anything (currently 'more').... (1 Reply)
Discussion started by: Dabheeruz
1 Replies

7. Shell Programming and Scripting

Search a string in a text file and add another string at the particular position of a line

I am having a text file which is having more than 200 lines. EX: 001010122 12000 BIB 12000 11200 1200003 001010122 2000 AND 12000 11200 1200003 001010122 12000 KVB 12000 11200 1200003 In the above file i want to search for string KVB and add/replace... (1 Reply)
Discussion started by: suryanarayana
1 Replies

8. Shell Programming and Scripting

Search a string in a text file and add another string at the end of line

Dear All I am having a text file which is having more than 200 lines. EX: 001010122 12000 BIB 12000 11200 1200003 001010122 2000 AND 12000 11200 1200003 001010122 12000 KVB 12000 11200 1200003 In the above file i want to search for string KVB... (5 Replies)
Discussion started by: suryanarayana
5 Replies

9. Shell Programming and Scripting

Search string within a file and list common words from the line having the search string

Hi, Need your help for this scripting issue I have. I am not really good at this, so seeking your help. I have a file looking similar to this: Hello, i am human and name=ABCD. How are you? Hello, i am human and name=PQRS. I am good. Hello, i am human and name=ABCD. Good bye. Hello, i... (12 Replies)
Discussion started by: royzlife
12 Replies

10. UNIX for Dummies Questions & Answers

Search for a string,delete the line and replace with new string in a file

Hi Everyone, I have a requirement in ksh where i have a set of files in a directory. I need to search each and every file if a particular string is present in the file, delete that line and replace that line with another string expression in the same file. I am very new to unix. Kindly help... (10 Replies)
Discussion started by: Pradhikshan
10 Replies
DtSearchQuery(library call)											       DtSearchQuery(library call)

NAME
DtSearchQuery -- Perform a DtSearch database search for a specified query SYNOPSIS
#include <Dt/Search.h> int DtSearchQuery( void *qry, char *dbname, int search_type, char *date1, char *date2, DtSrResult **results, long *resultscount, char *stems, int *stemcount); DESCRIPTION
DtSearchQuery is the DtSearch API search function. DtSearchQuery is passed a query string and some search options, performs the requested search, and if successful returns a linked list of DtSrResult structures representing the documents satisfying the search. The results list contains information about the documents that can be used for subsequent retrievals, as well as information suitable for display to an end user. Search Types DtSearchQuery supports three types of searches: P, W, and S. Type P Search Query Strings Query strings for search type P have the simplest syntax, namely a sequence of words separated by ASCII whitespace. Punctuation and invalid words are silently discarded by the search engine. The only possible syntax error is that all query words happen to be invalid in the lan- guage of the database. Search type P is often used to implement a limited Query-by-Example (QBE) search paradigm. In this scenario, users typically paste document text from whatever source into a query string text field. Their expectation is that the search engine will return the documents in the database that are "most similar" to the text of the query string, and the statistical sort of the results list usually satisfies that expectation. Note that although search type P does not use boolean syntax, it is actually implemented as a stemmed search (type S search) with implied boolean ORs between words. Types S and W Boolean Query Strings Query strings for search types S (stemmed boolean) and W (exact word boolean) must be syntactically valid boolean expressions as described below. Any string that does not match a valid expression rule is invalid and will fail with an error message. Query words for all search types may be entered in any codeset for a supported DtSearch language, including multibyte languages. Words may be identified as invalid by the language module of the database for a number of reasons including any words that would not have been indexed because they are too short, too long, on the stop list, etc. With one exception, linguistically invalid words result in a syntax error. The exception is in the case of an "all ANDs" query, where invalid words and valid words that happen not to be in the database are silently erased from the query string. The boolean query operators are the ASCII metacharacters: '&' for AND, '|' for OR, '~' for NOT, '(' and ')' for open and close parentheses respectively, and '@ nnn' for collocation expressions. All expression tokens are separated by ASCII whitespace. Typically this i 1 or more space or tab characters. Omitting whitespace separators is legal if it can be done unambiguously. For example "word1&word2" is a legal expression but "word1word2" would be interpreted as a single word token. The ASCII "at" sign (@) marks a special boolean collocation operator. The collocation operator has the syntax "@n...", the ASCII "at" sign followed by one or more ASCII numeric digits, representing an integer with value greater than zero. Collocation is a variation of the AND search where a user can specify the maximum distance in bytes between any two words. In most languages a byte is equivalent to a character position. For example to find "ice" and "cream" separated by no more than five characters, the search query "ice @5 cream" may be used. Unlike other boolean operators, the collocation operator can apply only to naked word tokens, not other expressions. Searches including collocation operators are slower than searches without them, and can be much slower for common words. There are a maximum of 8 distinct word tokens. Collocation operators count as part of the 8. There is no limit to the number of operators, as long as they match the syntax rules. Note: Collocation operators are only supported for "Austext flavor" databases. The default flavor of database created by dtsrcreate is "Dtinfo flavor," which does not support collocation. Boolean Query Syntax Rules There are only 6 syntax rules and the rules are recursive. Ambiguity is resolved by precedence and associativity rules. 1. valid_expression := word_token A valid expression can be just a valid naked word token. Semantically, the expression returns all documents containing the speci- fied word. The word_token must be a valid word in the language of the database being searched. 2. valid_expression := valid_expression '&' valid_expression The ASCII ampersand character is the AND character. Semantically, it returns all documents satisfying both the first and second expressions (boolean intersection). AND is also the "implied" boolean operator in the following sense: the query parser will insert an ampersand between words or expressions that otherwise would be separated only by whitespace. For example "word1 word2" becomes "word1 & word2". 3. valid_expression := valid_expression '|' valid_expression The ASCII virgule (vertical slash) character is the OR character. It means return all documents satisfying either the first or the second expression (boolean union). 4. valid_expression := '(' valid_expression ')' Valid expressions may be recursively nested in ASCII open and close parentheses characters. The query parser "forgives" two com- mon human errors. It will automatically discard excessive close parentheses characters, and it will automatically generate close parentheses characters if necessary at the end of a query. For example, "aaa | (bbb & ccc)))))) ddd" becomes "aaa | ( bbb & ccc) & ddd", and "aaa ((bbbb" becomes "aaa ( ( bbb ) )". 5. valid_expression := '~' valid_expression The ASCII tilde character is the unary NOT operator. It returns every document in the database that is not in the set satisfying the expression. 6. valid_expression := word_token collocation_operator word_token Collocation operators are permitted only between words, not expressions. Each of the word tokens and the collocation operator itself occupy slots in the table of 8 maximum word tokens. Boolean Associativity and Precedence Table In order from highest precedence to lowest: Associativity Operator Example (none) COLLOC right NOT "aaa~bbb" resolved as "aaa & (~(bbb)" left AND "aaa bbb ccc" resolved as "(aaa & bbb) & ccc" left OR "aaa|bbb|ccc" resolved as "(aaa | bbb) | ccc" (none) naked word Example Boolean Queries aaa bbb ccc Returns all records that contain at least one occurrence of all three words. aaa | (bbb ~ccc) Retrieves all records containing "aaa" and also all records containing "bbb", but not "ccc". aaa ~(aaa @1 bbb) Returns all records containing "aaa" but omits those where "aaa" is one character away from "bbb". It is possible to formulate a query that requires retrieving all records in the database that contain none of the query words (for example, ~aaa. Users should be warned that in a large database such a search can take a very long time. Using the implied associativity and precedence rules, the ambiguous query string aaa ~bbb | ccc ~ddd @10 eee is disambiguated as (aaa & (~bbb)) | (ccc & (~(ddd @10 eee))). ARGUMENTS
search_type Specifies the type of search to perform. Valid values are P, W, and S. Search type P indicates that the query string is a sequence of words separated by ASCII whitespace. It requests that the words be stemmed prior to searching, that all documents containing any of the words be returned, that the results list be statistically sorted, and that no more than the top MaxResults list items be returned where MaxResults is the current value returned from DtSearchGetMaxResults. Note that a type P search is identical to a type S boolean search with an implied boolean OR between words. Search types W and S are boolean query searches. They indicate that the query string is a sequence of words and boolean operators matching the syntax described under "Types S and W Boolean Query Strings" above. Type S requests that words be stemmed prior to searching. Type 'W' requests that words be left unstemmed. Both types request that all documents containing the combinations of query words specified by the boolean operations be returned, that the results list be statistically sorted if possible, and that no more than the top MaxResults list items be returned whereMaxResults is the cur- rent value returned from DtSearchGetMaxResults. dbname Specifies which database is to be searched. It is any one of the database name strings returned from DtSearchInit or DtSearchReinit. If dbname is NULL, the first database name string is used. Within the specified database, searches will be restricted to those documents whose DtSrKeytype.is_selected field is nonzero. date1 and date2" 10 Specify a range of document dates to use for the search. Only documents within the specified range will be returned on the results list. date1 is the older end of the range and if not NULL, requests DtSearch to return only those records younger than (that is, after) the specified date. date2 is the younger end of the range and if not NULL, requests DtSearch to return only those records older than (that is before) the specified date. It is valid to specify just one of the arguments. Undated documents always qualify for a results list regardless of search date strings. The format of a valid date string is described in DtSearchValidDateString(3). stems and stemscount" 10 Specify a character buffer to hold parsed and stemmed words and a variable to receive the number of stored words. stems and stemscount are optional; they can be NULL. However, if either is specified, they must both be specified. If specified stemsmust point to a character buffer large enough to hold DtSrMAX_STEMCOUNT by DtSrMAXWIDTH_HWORD bytes. An array of parsed and stemmed query words will be stored here by the API for use by a later call to DtSearchHighlight. The size of the array will be stored in stemscount. results and resultscount" 10 Specify where a pointer to the results list will be stored and a variable to receive the number of items on the list. Results lists can be manipulated with several utility functions. In DtSearch, frequency of occurrence information is maintained for words across the whole database and within documents. For most queries, results lists are sorted by this statistical information and presented to the user as a "proximity" number for each doc- ument on the list. Proximity is meant to appear to a user as a distance, or a measure of the nearness of the query to the docu- ment. Conceptually, the smaller the proximity the "closer" the document is to the query and the more likely it will be valuable to the user DtSearch searches only one database at a time and returns only results lists for that single database. However, browsers often provide the illusion of simultaneous searches in multiple databases, merging the results lists by proximity when completed. Since the domain of knowledge and density of words and records may vary from database to database, the value of proximity numbers may similarly vary, and some databases may be underrepresented on merged results lists. RETURN VALUE
This function has three common return codes. DtSrOK is returned, as well as a results list and stems array, when the search was completely successful. DtSrNOTAVAIL is returned when the query was valid but the search was unsuccessful (that is, no set of documents matched the query). There are usually no messages with DtSrNOTAVAIL. DtSrFAIL is returned when the search was unsuccessful, usually because of an invalid query, and user messages on the MessageList explain why. Any API function can also return DtSrREINIT and the return codes for fatal engine errors at any time. SEE ALSO
DtSrAPI(3), DtSearchReinit(3), DtSearchGetMaxResults(3), DtSearchSetMaxResults(3), DtSearchGetKeytypes(3), DtSearchValidDateString(3), DtSearchSortResults(3), DtSearchFreeResults(3), DtSearchHighlight(3) DtSearchQuery(library call)
All times are GMT -4. The time now is 09:31 AM.
Unix & Linux Forums Content Copyright 1993-2022. All Rights Reserved.
Privacy Policy