Sponsored Content
Top Forums Shell Programming and Scripting match range of different numbers by AWK Post 302352901 by repinementer on Monday 14th of September 2009 03:07:20 AM
Old 09-14-2009
Hey sorry for the troule
A small query. Where do I need to change the script for the following input(New kind of input(2ndone) in this every value at the end ends with additional comma)

Old-input
Code:
H19	1874741	2075014	-	619,123,113,135,1318	0,700,903,1111,1342
AF232216	77573119	77573241	-	122	0
AJ012497	168277851	168277971	-	131	0
X74605	153317693	153317967	-	274	0
AJ609435	120809513	120809640	-	128	0
AY216680	42520523	42521690	+	15,123	0,1044
EF212256	131009249	131009385	+	136	0
AY122469	50119368	50119432	-	64	0

Old-script
Code:
#!/usr/bin/awk -f 

BEGIN {
   OFS="\t"; ORS="\n" 
}
NF {
  sec = $2; fifth = split($5, _fifth, ","); sixth = split($6, _sixth, ",")
  counter = rec = ""; key = $1; flag = $4; sub(/[^ \t*]*/, "")
  dummy = sprintf("%*s", length(key),x)
  for (i=1; i<=sixth; i++) {
    second_third = sec + _sixth[i] FS _fifth[i] + sec + _sixth[i] 
    third_second = _fifth[i] + sec + _sixth[i] FS sec + _sixth[i] 
    if (flag == "+")
      rec = rec ? rec RS key dummy OFS second_third OFS flag : key OFS second_third  OFS flag
    else if (flag == "-")
      rec = rec ? rec RS key dummy OFS third_second OFS flag : key OFS third_second  OFS flag
  }
  {print (flag == "+" ? rec : rec) >>"Exon_output1.txt"}

Old-output
Code:
H19	1875360 1874741	-
H19   	1875564 1875441	-
H19   	1875757 1875644	-
H19   	1875987 1875852	-
H19   	1877401 1876083	-
AF232216	77573241 77573119	-
AJ012497	168277982 168277851	-
X74605	153317967 153317693	-
AJ609435	120809641 120809513	-
AY216680	42520523 42520538	+
AY216680        	42521567 42521690	+
EF212256	131009249 131009385	+
AY122469	50119432 50119368	-

New kind of input but need the same output like the above input

New-input needs old output

Code:
H19	1874741	2075014	-	619,123,113,135,1318,	0,700,903,1111,1342,
AF232216	77573119	77573241	-	122,	0,
AJ012497	168277851	168277971	-	131	0
X74605	153317693	153317967	-	274,	0,
AJ609435	120809513	120809640	-	128	0
AY216680	42520523	42521690	+	15,123,	0,1044,
EF212256	131009249	131009385	+	136,	0,
AY122469	50119368	50119432	-	64,	0,


Last edited by repinementer; 09-14-2009 at 04:12 AM..
 

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

match numbers (awk)

i would like to enter (user input) a bunch of numbers seperated by space: 10 15 20 25 and use awk to print out any lines in a file that have matching numbers so output is: 22 44 66 55 (10) 77 (20) (numbers 10 and 20 matched for example) is this possible in awk . im using gawk for... (5 Replies)
Discussion started by: tanku
5 Replies

2. Shell Programming and Scripting

Match real numbers in AWK

I am looking for a better way to match real numbers within a specified tolerance range. My current code is as follows: if ($1 !~ /^CASE/) for(i=1;i in G;i++) if (G >= $5-1 && G <= $5+1) { print $1,$4,$5,J,G } else { print $1,"NO MATCH" } where $5 and G are... (3 Replies)
Discussion started by: cold_Que
3 Replies

3. Shell Programming and Scripting

awk to match a numeric range specified by two columns

Hi Everyone, Here's a snippet of my data: File 1 = testRef2: A1BG - 13208 13284 AAA1 - 34758475 34873943 AAAS - 53701240 53715412File 2 = 42MLN.3.bedS2: 13208 13208 13360 13363 13484 13518 13518My awk script: awk 'NR == FNR{a=$1;next} {$1>=a}{$1<=a}{print... (5 Replies)
Discussion started by: heecha
5 Replies

4. Shell Programming and Scripting

Range of numbers in HEX using AWK

Hi , How do i found out all the number in a range ( HEX) for example Input is 15CF:15D2 Output needed 15CF 15D0 15D1 15D2 Thanks (2 Replies)
Discussion started by: greycells
2 Replies

5. Shell Programming and Scripting

Awk numeric range match only one digit?

Hello, I have a text file with lines that look like this: 1974 12 27 -0.72743 -1.0169 2 1.25029 1974 12 28 -0.4958 -0.72926 2 0.881839 1974 12 29 -0.26331 -0.53426 2 0.595623 1974 12 30 7.71432E-02 -0.71887 3 0.723001 1974 12 31 0.187789 -1.07114 3 1.08748 1975 1 1 0.349933 -1.02217... (2 Replies)
Discussion started by: meridionaljet
2 Replies

6. Shell Programming and Scripting

Complex match of numbers between 2 files awk script

Hello to all, I hope some awk guru could help me. I have 2 input files: File1: Is the complete database File2: Contains some numbers which I want to compare File1: "NUMBERKEY","SERVICENAME","PARAMETERNAME","PARAMETERVALUE","ALTERNATENUMBERKEY"... (9 Replies)
Discussion started by: Ophiuchus
9 Replies

7. Shell Programming and Scripting

awk : match only the pattern string , not letters or numbers after that.

Hi Experts, I am finding difficulty to get exact match: file OPERATING_SYSTEM=HP-UX LOOPBACK_ADDRESS=127.0.0.1 INTERFACE_NAME="lan3" IP_ADDRESS="10.53.52.241" SUBNET_MASK="255.255.255.192" BROADCAST_ADDRESS="" INTERFACE_STATE="" DHCP_ENABLE=0 INTERFACE_NAME="lan3:1"... (6 Replies)
Discussion started by: rveri
6 Replies

8. Shell Programming and Scripting

Match on a range of numbers

Hi, I'm trying to match a filename that could be called anything from vout001 to vout252 and was trying to do a small test but I'm not getting the result I thought I would.. Can some one tell me what I'm doing wrong? *****@********>echo $mynumber ... (4 Replies)
Discussion started by: Jazmania
4 Replies

9. Shell Programming and Scripting

Get range out using sed or awk, only if given pattern match

Input: START OS:: UNIX Release: xxx Version: xxx END START OS:: LINUX Release: xxx Version: xxx END START OS:: Windows Release: xxx Version: xxx ENDHere i am trying to get all the information between START and END, only if i could match OS Type. I can get all the data between the... (3 Replies)
Discussion started by: Dharmaraja
3 Replies

10. Shell Programming and Scripting

awk to print text in field if match and range is met

In the awk below I am trying to match the value in $4 of file1 with the split value from $4 in file2. I store the value of $4 in file1 in A and the split value (using the _ for the split) in array. I then strore the value in $2 as min, the value in $3 as max, and the value in $1 as chr. If A is... (6 Replies)
Discussion started by: cmccabe
6 Replies
KAWARI8(6)							   Games Manual 							KAWARI8(6)

NAME
kawari_encode, kawari_encode2, kawari_decode2 -- kawari 8.0 encoder/decoder SYNOPSIS
kawari_encode [file ...] kawari_encode2 [file ...] kawari_decode2 [file ...] DESCRIPTION
This manual page documents briefly the kawari command. This manual page was written for the Debian distribution because the original program does not have a manual page. Instead, it has docu- mentation written in HTML format. For detailed descriptions, see doc-base. kawari_encode encodes kawari scripts to an encoded file. So the users for the scripts cannot easily read the content. It can be used to protect the content of Kawari scripts. It takes several text files as inputs and converts them to .kaw files separately. kawari_encode2 is an advanced kawari_encode. It is able to assign a symmetric key like some encrypting systems. The key affects the encod- ing system. Users need the key to decode them. kawari_decode2 is a decoder of the .kaw files. It takes several .kaw files and convert them back to .txt files. If the kaw files is encoded by kawari_encode2, the key must be provided correctly for decoding. AUTHOR
This manual page was written by Ying-Chun Liu (PaulLiu) <grandpaul@gmail.com> for the Debian system (but may be used by others). This man- ual page is in public domain and is freely reproduced, distributed, transmitted, used, modified, built upon, or otherwise exploited by any- one for any purpose, commercial or non-commercial, and in any way, including by methods that have not yet been invented or conceived. KAWARI8(6)
All times are GMT -4. The time now is 07:57 PM.
Unix & Linux Forums Content Copyright 1993-2022. All Rights Reserved.
Privacy Policy