- Community Home
- >
- Servers and Operating Systems
- >
- Operating Systems
- >
- Operating System - OpenVMS
- >
- Re: Can you do a F$EXTRACT on a PIPE output
Categories
Company
Local Language
Forums
Discussions
Forums
- Data Protection and Retention
- Entry Storage Systems
- Legacy
- Midrange and Enterprise Storage
- Storage Networking
- HPE Nimble Storage
Discussions
Forums
Discussions
Discussions
Discussions
Forums
Discussions
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
- BladeSystem Infrastructure and Application Solutions
- Appliance Servers
- Alpha Servers
- BackOffice Products
- Internet Products
- HPE 9000 and HPE e3000 Servers
- Networking
- Netservers
- Secure OS Software for Linux
- Server Management (Insight Manager 7)
- Windows Server 2003
- Operating System - Tru64 Unix
- ProLiant Deployment and Provisioning
- Linux-Based Community / Regional
- Microsoft System Center Integration
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Community
Resources
Forums
Blogs
- Subscribe to RSS Feed
- Mark Topic as New
- Mark Topic as Read
- Float this Topic for Current User
- Bookmark
- Subscribe
- Printer Friendly Page
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
10-14-2010 05:20 AM
10-14-2010 05:20 AM
			
				
					
						
							Can you do a F$EXTRACT on a PIPE output
						
					
					
				
			
		
	
			
	
	
	
	
	
I'm trying to extract certain sections of lines in a report. First I find the lines I want and then I attempt to extract the section of that line I want. I would like to be able to do this without creating any temporary files, but just using the sys$input. Here is my attempt:
pipe typ sample.rep | search/match=and SYS$INPUT 8148, 5.00 | READ/END_OF_FILE=exit SYS$inPUT record F$EXTRACT(12,10,RECORD)
It works up to the second pipe, I'm just not able to 'extract' the section of the line I want out of the terminal output. Can anyone help me out please?
Thanks,
Niall
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
10-14-2010 05:51 AM
10-14-2010 05:51 AM
			
				
					
						
							Re: Can you do a F$EXTRACT on a PIPE output
						
					
					
				
			
		
	
			
	
	
	
	
	
(READ SYS$PIPE record ; record=F$EXTRACT(12,10,RECORD) ; define/job record &record)
A READ in a pipe can have no error/end label (where do You think the label "exit" is ?)
If You want to have read error handling, and/or read of more than one line, then pipe into a DCL command-file, which does a loop on READ SYS$PIPE: Your search most probably DOES output more than one line to the pipe !
The above SEARCH+READ only gets the first line, not what You want. use SEARCH/WINDOW=1 .
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
10-14-2010 06:04 AM
10-14-2010 06:04 AM
			
				
					
						
							Re: Can you do a F$EXTRACT on a PIPE output
						
					
					
				
			
		
	
			
	
	
	
	
	
Niall, what are you going to do with the result? Stick it in a logical?
And then what? What problem are you really trying to solve, and is convoluted DCL really the best way to go about that?
Here is some DCL that works for me.
I dropped the first pipe segment as search is perfectly able to read a file itself. It needs no help from type does it?
$ pipe typ tmp.tmp | search/match=and SYS$INPUT 8148, 5.00 | (read sys$pipe x ; x=f$extr(12,10,x) ; def/job x &x)
$ show log x
Using PERL this looks like:
$ perl -lne "print substr($_,12,10) if /8148/ && /5.00/" tmp.tmp
Or AWK if you prefer...
$ gawk "/8148/ && /5.00/ { print substr($_,13,10) }" tmp.tmp
If more string processing needs to take place, or more complex matching algorithms are needed (general, not specific values and/or more rigorous placement/anchors for the match strings), then a perl or awk solution with REGULAR EXPRESSIONS quickly becomes more advantageous.
For example:
$ perl -ne "print $1 if /^\s*8148.*?5.00(.{10})/" tmp.tmp
That REGEXPR says look for a like starting with (^) optional whitespace (\s*) followed by 8184 followed by any number of anything (.*?) up to 5.00, then save (()) 10 times anything (.{10}) into register $1
Often one of two of those number are variables which need to be picked up, and the string of 10 is really just a single word.
The line might then become
$perl -ne "print qq($2 $1) if /^\s*8148\s+([0-9.]+)\s*(\w+)/" tmp.tmp
^ = Begin of line
\s = whitespace
\s+ = 1 whitespace or more
\s* = any number of whitespace
[0-9.] any character in the range 0 - 9 or a period
[0-9.]+ = series of one or more of those
\w = a word character
\w+ = a word
qq() = double quoted string doing substitutions (avoid quote fights with DCL)
hth,
Hein
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
10-14-2010 06:07 AM
10-14-2010 06:07 AM
			
				
					
						
							Re: Can you do a F$EXTRACT on a PIPE output
						
					
					
				
			
		
	
			
	
	
	
	
	
$ pipe typ sample.rep | search/match=and SYS$INPUT 8148, 5.00 | @logical_from_pipe RECORD
$ record=f$trnlnm("RECORD","LNM$GROUP")
$ this = F$EXTRACT(12,10,RECORD)
Where logical_from_pipe.com is
http://www.mpp.mpg.de/~huber/util/com/logical_from_pipe.com
A version reading more than one line from pipe into logicals was posted by R.Boyd here (or at www.openvms.org ?), You can find my version on the above web location as logicals_from_pipe.com .
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
10-14-2010 06:12 AM
10-14-2010 06:12 AM
			
				
					
						
							Re: Can you do a F$EXTRACT on a PIPE output
						
					
					
				
			
		
	
			
	
	
	
	
	
Correction:
$ pipe search/match=and tmp.tmp 148, 5.00 | (read sys$pipe x ; x=f$extr(12,10,x) ; def/job x &x)
Using perl and defining a logical(*)
$perl -ne "$ENV{x} = substr($_,12,10) if /8148/ && /5.00/" tmp.tmp
$ show log x
(*) For the latter, see also
http://forums13.itrc.hp.com/service/forums/questionanswer.do?threadId=1408424
Hein
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
10-14-2010 07:27 AM
10-14-2010 07:27 AM
			
				
					
						
							Re: Can you do a F$EXTRACT on a PIPE output
						
					
					
				
			
		
	
			
	
	
	
	
	
pipe search/match=and sample.txt 8148, 5.00
AAAA 0 0 0 5.00 8148 AA1234 1426 2216 ...
AAAA 0 0 0 5.00 8148 AA12345 3287 2216 ...
AAAA 0 0 0 5.00 8148 AA756 703 2216 ...
With the new and improved pipe:
$ pipe search/match=and sample.txt 8148, 5.00 | (read sys$pipe info ; x=f$extr(37,4,info) ; y=f$extr(41,10,info) ; write sys$output x, y)
8148 AA1234
But what I want is:
8148 AA1234
8148 AA12345
8148 AA756
I'm sorry, but from your examples and links I can't figure out how to do it.
Thanks,
Niall
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
10-14-2010 07:54 AM
10-14-2010 07:54 AM
			
				
					
						
							Re: Can you do a F$EXTRACT on a PIPE output
						
					
					
				
			
		
	
			
	
	
	
	
	
It's possible that SORT can do it for you, depending on what the input file is really like (space aligned, etc). Making some assumptions about what you posted, an example:
$ type a.a
0000000001111111111222222222233333333334444444444555555555566666666667
1234567890123456789012345678901234567890123456789012345678901234567890
AAAA 0 0 0 5.00 8148 AA1234 1426 2216 ...
AAAA 0 0 0 5.00 8148 AA12345 3287 2216 ...
AAAA 0 0 0 5.00 8148 AA756 703 2216 ...
$ type a.srt
/field=(name=f1,pos:33,siz:4)
/field=(name=f2,pos:38,siz:4)
/field=(name=f3,pos:43,siz:9)
/condition=(name=c1,test=((f1 eq "5.00") and (f2 eq "8148")))
/include=(condition=c1)
/data=f2
/data=f3
$ sort a.a /spec=a.srt sys$output
8148 AA756
8148 AA1234
8148 AA12345
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
10-14-2010 07:54 AM
10-14-2010 07:54 AM
			
				
					
						
							Re: Can you do a F$EXTRACT on a PIPE output
						
					
					
				
			
		
	
			
	
	
	
	
	
hth
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
10-14-2010 07:55 AM
10-14-2010 07:55 AM
			
				
					
						
							Re: Can you do a F$EXTRACT on a PIPE output
						
					
					
				
			
		
	
			
	
	
	
	
	
I see that Graham and I got the same time stamp! :-)
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
10-14-2010 07:58 AM
10-14-2010 07:58 AM
			
				
					
						
							Re: Can you do a F$EXTRACT on a PIPE output
						
					
					
				
			
		
	
			
	
	
	
	
	
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
10-14-2010 07:59 AM
10-14-2010 07:59 AM
			
				
					
						
							Re: Can you do a F$EXTRACT on a PIPE output
						
					
					
				
			
		
	
			
	
	
	
	
	
Then you can not just use a 'one liner'.
You'll need a helper command file, or a better programming language.
For example, with tmp.com being
-----
$open/read pipe sys$pipe
$loop:
$read/end=done pipe rec
$write sys$output f$ext(37,17,rec)
$goto loop
$done:
----------
$ pipe search/match=and tmp.tmp 8148, 5.00 | @tmp
I suppose you could generate the helper on the fly, and delete. I sometimes 'embed' it in the main procedure, calling itself with a label to jump to.
------ $!test.com
$if p1.nes."" then goto 'p1
$pipe ... | @'f$env("procedure") print_it
:
$exit
$print_it:
$open/read ...
$loop:
$ ...
$goto loop
--------
But if you go that route, why not have the DCL script do the loop/search?
(Possible answer... too much data to process efficiently by DCL )
-----
$close/nolog tmp
$open/read tmp tmp.tmp
$loop:
$read/end=done tmp rec
$if f$len(rec).eq.f$loc("8148",rec) .or. f$len(rec).eq.f$loc("5.0",rec) then goto loop
$write sys$output f$ext(37,17,rec)
$goto loop
$done:
$close tmp
-------------
Or just using perl:
$ perl -lne "print $1 if /5.00\s+(8148.{10})/" tmp.tmp
But surely that little table is not the end goal.
And possible those 5.0 and 8148 are not really string constants.
So what are the prior and next steps?
What is the real problem you are trying to solve?
pipe's may or might not be useful in solving the real problem.
Perl or awk may or might not be more useful
Hein
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
10-14-2010 01:57 PM
10-14-2010 01:57 PM
			
				
					
						
							Re: Can you do a F$EXTRACT on a PIPE output
						
					
					
				
			
		
	
			
	
	
	
	
	
PIPE is great, but can often get too convoluted to be worthwhile. Pipe stages through command procedures to write more complex code.
You'd think that doing everything in memory would outperform writing to disk, but counterintuitively, PIPE is usually MUCH slower (but you avoid generating temp files and the need to clean up). For complex text processing a Perl script will usually be simpler and faster.
Regarding /ERROR or dealing with errors in general. Don't forget there are "&&" (if success) and "||" (if error) separators. Unfortunately you need to explicitly return status, if your mainline needs to know the result.
Examples:
$ PIPE (SHOW JUNK && SHOW TIME || EXIT &$STATUS.OR.%X10000000)
$ SHOW SYM $STATUS
$STATUS == "%X10038060"
or
$ PIPE (SHOW JUNK || EXIT &$STATUS.OR.%X10000000 && SHOW TIME ; SHOW PROCESS ; SHOW SYSTEM)
[.OR. with STS$M_INHIB_MSG to prevent duplicate error message when exiting the pipe.]
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
10-15-2010 01:19 AM
10-15-2010 01:19 AM
