|
Tony, I based my code on that sample. The code I use to create the file is: D IFS_File_Name S 256A D fd S 10I 0 D Open_Flag S 10I 0 D Mode_Flag S 10U 0 D Code_Page S 10U 0 Inz(819) // Remove file if it exists first, so we don't overwrite beg file seg RC=unlink(%TrimR(IFS_File_Name)); // Create file with correct code page, in text mode Open_Flag = O_CREAT + O_WRONLY + O_CODEPAGE; Mode_Flag = S_IWUSR + S_IRUSR + S_IRGRP + S_IROTH; fd=open(%TrimR(IFS_File_Name) :Open_Flag : Mode_Flag : Code_Page); // Close file RC=close(fd); // File Created - Open for text output Open_Flag = (O_WRONLY + O_TEXTDATA + O_APPEND); fd=open(%TrimR(IFS_File_Name) : Open_Flag); Tony Carolla <carolla@xxxxxxxxx> wrote: On 7/14/05, Jeffrey Young wrote: > > That is what I am trying to do. > I am creating the file directly on the IFS, and getting corrupted data in > the output, and unable to open the file in EXCL unless I first OPEN & SAVE > using NOTEPAD. > All suggestions are welcome. Here is a subproc I used to output to excel: P Excelify B D Excelify PR D Excelify PI // Standalones D fd S 10I 0 Inz D RC S 10I 0 Inz D UserName S 10A Inz(*User) D Today S D Inz(*Sys) D FileName S 43A Varying D OpenName S 200A Varying D EndOfSheet S 22A Inz('') // Constants D Tb1 C '' D Tb2 C '' D FilePrefix C '/home/mcare_appeals_Extracts/' D FileSuffix C '.XLS' D StartPCO C 'STRPCO' D OpenPrefix C 'STRPCCMD PCCMD(''\\10.10.4.15\root\- D home\mcare_appeals_extracts\' D OpenSuffix C '.xls'') PAUSE(*NO)' // Structures D Title1 DS Qualified D Chunk1 221A Inz('D style="text-align:center;">MedAmeri- D ca Billing Services, Inc. -- Medicar- D e Appeals Extract Listing- D ') D Title2 DS Qualified D Chunk1 368A Inz(' D align="center" border="1" style="wid- D th:800px;" title="Detail">D "center" bgcolor="blue" style="color- D :white;font-weight:bold;">SiteD th>Account#Patient_Name- D Bill_IDIns#D h>1st_ExtractCodeL- D ast_ExtractCodeUse- D rPmts_AfterPmts_To- D tal') D DSTitle DS Qualified D Chunk1 12A Inz('Result Code ') D RCChoice 3A Inz D Chunk2 4A Inz(' -- ') D EarlyDate 10A Inz D DSDetail DS Qualified D Chunk1 67A Inz('') D Site 3A Inz D Chunk2 9A Inz(Tb1) D Account 15A Inz D Chunk3 27A Inz(Tb2) D Patname 20A Inz D Chunk4 9A Inz(Tb1) D BillId 2A Inz D Chunk5 27A Inz(Tb2) D Insur 5A Inz D Chunk6 9A Inz(Tb1) D FirstXDate 10A Inz D Chunk7 27A Inz(Tb2) D FirstXCode 3A Inz D Chunk8 9A Inz(Tb1) D LastXDate 10A Inz D Chunk9 27A Inz(Tb2) D LastXCode 3A Inz D Chunk10 9A Inz(Tb1) D UserName 10A Inz D Chunk11 27A Inz(Tb2) D PmtsAfter 10A Inz D Chunk12 9A Inz(Tb1) D PmtTot 10A Inz D Chunk13 10A Inz('') /Free FileName=FilePrefix+%Trim(UserName)+FileSuffix; // Remove file if it exists first, so we don't overwrite beg file seg RC=unlink(FileName); // Create file with correct code page, in text mode fd=open(Filename:O_CREAT+O_WRONLY+O_CODEPAGE: S_IWUSR+S_IRUSR+S_IRGRP+S_IROTH:819); RC=close(fd); fd=open(FileName:O_WRONLY+O_TEXTDATA); // Write header RC=write(fd:%addr(Title1):%Size(Title1)); DSTitle.RCChoice=DFRes; DSTitle.EarlyDate=%Char(Today:*usa); RC=write(fd:%addr(DSTitle):%Size(DSTitle)); RC=write(fd:%addr(Title2):%Size(Title2)); // Write detail lines If %Open(MCareTmp); Close MCareTmp; EndIf; Open MCareTmp; Read Mctmp Mti; Dow Not %EOF(MCareTmp); DSDetail.Site=Mti.Tmsite; // Prevent Excel from recognizing account numbers as dates DSDetail.Account='="' + Mti.Tmacct + '"'; DSDetail.Patname=Mti.TMPatName; DSDetail.BillId=Mti.TMBillId; DSDetail.Insur=Mti.Tmins; DSDetail.FirstXDate=Mti.Tmx1d; DSDetail.FirstXCode=Mti.TMX1c; DSDetail.LastXDate=Mti.Tmxld; DSDetail.LastXCode=Mti.Tmxlc; DSDetail.UserName=Mti.TMUser; DSDetail.PmtsAfter=Mti.Tmaft; DSDetail.PmtTot=Mti.Tmtot; RC=write(fd:%addr(DSDetail):%Size(DSDetail)); Read MCTmp Mti; EndDo; RC=write(fd:%addr(EndOfSheet):%size(EndOfSheet)); RC=close(fd); OpenName=OpenPrefix+%Trim(UserName)+OpenSuffix; RC=system(StartPCO); RC=system(OpenName); Return; /End-Free P Excelify E Hope this helps...
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.