MVSFORUMS.com Forum Index MVSFORUMS.com
A Community of and for MVS Professionals
 
 FAQFAQ   SearchSearch   Quick Manuals   RegisterRegister 
 ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

Change the record date to Next Friday date using DFSORT

 
Post new topic   Reply to topic   printer-friendly view    MVSFORUMS.com Forum Index -> Utilities
View previous topic :: View next topic  
Author Message
hsubra
Beginner


Joined: 18 Jun 2003
Posts: 25
Topics: 11

PostPosted: Thu Jun 15, 2006 8:23 am    Post subject: Change the record date to Next Friday date using DFSORT Reply with quote

Hi ,

I have date in a file 'YYMMDD' format needs to be changed into next friday date .
Currently , i have a file(DATEFILE) where i store all the Friday date for the entire year and the program which reads the INPUT file and DATEFILE, convert the INPUT file date to next friday date.

Example

Input file:

A1B1C1 060104 500.00
A1B1C1 060105 200.00
A1B1C1 060216 100.00
A2B2C2 060607 700.00
A2B2C2 060616 100.00

Output file :

A1B1C1 060106 700.00
A1B1C1 060217 100.00
A2B2C2 060609 700.00
A2B2C2 060616 100.00

Now , I want to do it in ICETOOL. Please help me . Thank You !
Cheers,
Subra
Back to top
View user's profile Send private message
kolusu
Site Admin
Site Admin


Joined: 26 Nov 2002
Posts: 12367
Topics: 75
Location: San Jose

PostPosted: Thu Jun 15, 2006 8:42 am    Post subject: Reply with quote

hsubra,

Sort Products do NOT have the capability of determing the day of the week.

Kolusu
_________________
Kolusu - DFSORT Development Team (IBM)
DFSORT is on the Web at:
www.ibm.com/storage/dfsort

www.linkedin.com/in/kolusu
Back to top
View user's profile Send private message Send e-mail Visit poster's website
hsubra
Beginner


Joined: 18 Jun 2003
Posts: 25
Topics: 11

PostPosted: Thu Jun 15, 2006 9:15 am    Post subject: Reply with quote

Thanks Kolusu.

Consider , if i have another DATEFILE where i store the all FRIDAYs. Is it possible to compare the DATEFILE and INFILE and replace the dates from DATEFILE?

DATEFILE: (WHICH CONTAINS ALL FRIDAY'S)
060106
060113
060120
060127
060203
060210
060217
060224
060303
060310
060317
060324
060331
060407
060414
060421
060428
060505
060512
060519
060526
060602
060609
060616
060623
060630
060707
060714
060721
060728

Input file:

A1B1C1 060104 500.00
A1B1C1 060105 200.00
A1B1C1 060216 100.00
A2B2C2 060607 700.00
A2B2C2 060616 100.00


Expected Output file :

A1B1C1 060106 500.00
A1B1C1 060106 200.00
A1B1C1 060217 100.00
A2B2C2 060609 700.00
A2B2C2 060616 100.00


Thanks ,
Subra
Back to top
View user's profile Send private message
kolusu
Site Admin
Site Admin


Joined: 26 Nov 2002
Posts: 12367
Topics: 75
Location: San Jose

PostPosted: Thu Jun 15, 2006 11:08 am    Post subject: Reply with quote

hsubra,

well there is a way to do what you asked for. But you need to create the friday date file a little different so that we can use it as symnames. Create the firday date file as follows. Any given year will have a min of 52 weeks and max of 53 weeks.
Code:

FRI01,C'20060106'
FRI02,C'20060113'
FRI03,C'20060120'
FRI04,C'20060127'
FRI05,C'20060203'
FRI06,C'20060210'
FRI07,C'20060217'
FRI08,C'20060224'
FRI09,C'20060303'
FRI10,C'20060310'
FRI11,C'20060317'
FRI12,C'20060324'
FRI13,C'20060331'
FRI14,C'20060407'
FRI15,C'20060414'
....

FRI50,C'20061215'
FRI51,C'20061222'
FRI52,C'20061229'
FRI53,C'20070105'


Now we use this file as look up file and modify the dates.I also see that you are summing the AMOUNT values at pos 15. I assumed that your input file has LRECL of 80 and FB recfm dataset.

Code:

//STEP0100 EXEC PGM=SORT                             
//SYSOUT   DD SYSOUT=*                               
//SYMNAMES DD DSN=your friday date 80 byte file,                 
//            DISP=SHR                               
//SORTIN  DD *                                       
A1B1C1 060104 500.00                                 
A1B1C1 060105 200.00                                 
A1B1C1 060216 100.00                                 
A2B2C2 060607 700.00                                 
A2B2C2 060616 100.00                                 
//SORTOUT DD SYSOUT=*                               
//SYSIN DD *                                         
 SORT FIELDS=(01,06,CH,A,                           
              89,08,CH,A)                           
                                                     
 INREC IFTHEN=(WHEN=INIT,                                   
               OVERLAY=(81:C'20',8,6)),                     
       IFTHEN=(WHEN=(81,8,CH,LE,FRI01),                     
               OVERLAY=(89:FRI01)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI02,AND,81,8,CH,GT,FRI01),
               OVERLAY=(89:FRI02)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI03,AND,81,8,CH,GT,FRI02),
               OVERLAY=(89:FRI03)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI04,AND,81,8,CH,GT,FRI03),
               OVERLAY=(89:FRI04)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI05,AND,81,8,CH,GT,FRI04),
               OVERLAY=(89:FRI05)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI06,AND,81,8,CH,GT,FRI05),
               OVERLAY=(89:FRI06)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI07,AND,81,8,CH,GT,FRI06),
               OVERLAY=(89:FRI07)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI08,AND,81,8,CH,GT,FRI07),
               OVERLAY=(89:FRI08)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI09,AND,81,8,CH,GT,FRI08),
               OVERLAY=(89:FRI09)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI10,AND,81,8,CH,GT,FRI09),
               OVERLAY=(89:FRI10)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI11,AND,81,8,CH,GT,FRI10),
               OVERLAY=(89:FRI11)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI12,AND,81,8,CH,GT,FRI11),
               OVERLAY=(89:FRI12)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI13,AND,81,8,CH,GT,FRI12),
               OVERLAY=(89:FRI13)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI14,AND,81,8,CH,GT,FRI13),
               OVERLAY=(89:FRI14)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI15,AND,81,8,CH,GT,FRI14),
               OVERLAY=(89:FRI15)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI16,AND,81,8,CH,GT,FRI15),
               OVERLAY=(89:FRI16)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI17,AND,81,8,CH,GT,FRI16),
               OVERLAY=(89:FRI17)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI18,AND,81,8,CH,GT,FRI17),
               OVERLAY=(89:FRI18)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI19,AND,81,8,CH,GT,FRI18),
               OVERLAY=(89:FRI19)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI20,AND,81,8,CH,GT,FRI19),
               OVERLAY=(89:FRI20)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI21,AND,81,8,CH,GT,FRI20),
               OVERLAY=(89:FRI21)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI22,AND,81,8,CH,GT,FRI21),
               OVERLAY=(89:FRI22)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI23,AND,81,8,CH,GT,FRI22),
               OVERLAY=(89:FRI23)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI24,AND,81,8,CH,GT,FRI23),
               OVERLAY=(89:FRI24)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI25,AND,81,8,CH,GT,FRI24),
               OVERLAY=(89:FRI25)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI26,AND,81,8,CH,GT,FRI25),
               OVERLAY=(89:FRI26)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI27,AND,81,8,CH,GT,FRI26),
               OVERLAY=(89:FRI27)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI28,AND,81,8,CH,GT,FRI27),
               OVERLAY=(89:FRI28)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI29,AND,81,8,CH,GT,FRI28),
               OVERLAY=(89:FRI29)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI30,AND,81,8,CH,GT,FRI29),
               OVERLAY=(89:FRI30)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI31,AND,81,8,CH,GT,FRI30),
               OVERLAY=(89:FRI31)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI32,AND,81,8,CH,GT,FRI31),
               OVERLAY=(89:FRI32)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI33,AND,81,8,CH,GT,FRI32),
               OVERLAY=(89:FRI33)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI34,AND,81,8,CH,GT,FRI33),
               OVERLAY=(89:FRI34)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI35,AND,81,8,CH,GT,FRI34),
               OVERLAY=(89:FRI35)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI36,AND,81,8,CH,GT,FRI35),
               OVERLAY=(89:FRI36)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI37,AND,81,8,CH,GT,FRI36),
               OVERLAY=(89:FRI37)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI38,AND,81,8,CH,GT,FRI37),
               OVERLAY=(89:FRI38)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI39,AND,81,8,CH,GT,FRI38),
               OVERLAY=(89:FRI39)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI40,AND,81,8,CH,GT,FRI39),
               OVERLAY=(89:FRI40)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI41,AND,81,8,CH,GT,FRI40),
               OVERLAY=(89:FRI41)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI42,AND,81,8,CH,GT,FRI41),
               OVERLAY=(89:FRI42)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI43,AND,81,8,CH,GT,FRI42),
               OVERLAY=(89:FRI43)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI44,AND,81,8,CH,GT,FRI43),
               OVERLAY=(89:FRI44)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI45,AND,81,8,CH,GT,FRI44),
               OVERLAY=(89:FRI45)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI46,AND,81,8,CH,GT,FRI45),
               OVERLAY=(89:FRI46)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI47,AND,81,8,CH,GT,FRI46),
               OVERLAY=(89:FRI47)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI48,AND,81,8,CH,GT,FRI47),
               OVERLAY=(89:FRI48)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI49,AND,81,8,CH,GT,FRI48),
               OVERLAY=(89:FRI49)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI50,AND,81,8,CH,GT,FRI49),
               OVERLAY=(89:FRI50)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI51,AND,81,8,CH,GT,FRI50),
               OVERLAY=(89:FRI51)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI52,AND,81,8,CH,GT,FRI51),
               OVERLAY=(89:FRI52)),                         
       IFTHEN=(WHEN=(81,8,CH,LE,FRI53,AND,81,8,CH,GT,FRI52),
               OVERLAY=(89:FRI53))                         
                                               
 OUTREC FIELDS=(01,07,91,06,14,67,1,6,89,8)     
 OUTFIL OUTREC=(1,80),                         
        REMOVECC,NODETAIL,                     
   SECTIONS=(81,14,                             
    TRAILER3=(01,14,                           
              TOT=(15,6,UFF,EDIT=(IIIIIIIT.TT)),
              80:X))                           
/*                                             


Hope this helps...

Cheers

Kolusu
_________________
Kolusu - DFSORT Development Team (IBM)
DFSORT is on the Web at:
www.ibm.com/storage/dfsort

www.linkedin.com/in/kolusu
Back to top
View user's profile Send private message Send e-mail Visit poster's website
Display posts from previous:   
Post new topic   Reply to topic   printer-friendly view    MVSFORUMS.com Forum Index -> Utilities All times are GMT - 5 Hours
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


MVSFORUMS
Powered by phpBB © 2001, 2005 phpBB Group