|
Sounds to me as if you are going to have to resort to using XML-SAX. I could make it work with XML-INTO but the structures are huge and if you only need some of them ...
Don't bother writing a scanner yourself when XML-INTO will do it for you. You could also use Scott Klement's port of eXpat but I find XML-SAX more than good enough.
If you want you'll find an explanation and example of XML-SAX here: http://www.mcpressonline.com/programming/rpg/rpg-has-sax-appeal.html
And I have a sample XML-SAX program here that should help you: www.Partner400.com/Examples/XMLSAXTST.HTM - It will process any XML document and print out exactly what it finds. It should be useful in helping you to work out what elements you will receive and what the data will look like.
Good luck.
Other comments in-line below.
On 2014-05-20, at 3:51 PM, Alan Cassidy <ACassidy@xxxxxxxxxxxxxx> wrote:
Hi Jon,
Not all the <Data..> elements are empty, just some of them, a lot of them, but XML-INTO apparently returns all blanks. I'm only interested in the ones that do have data for this project.
Any parser will return empty elements if they are present. There's normally a distinction between empty e.g. <A><B>First B</B><B></B></A> where the second B element is present but empty and <A><B>First B</B></A> where only one B element is supplied. Looks to me as if their XML generator is a bit "lazy" and always writing out all the tags even when there is no data.
The very first Data of the very first Row should be returning data (header text) but does not. I've been checking that one, and spot check a couple of others.
If you post that bit of the XML I might be able to spot it but ...
!! Oops, the real first repeating element is "<Worksheet". Maybe that's the problem? Wow there's 24 <Worksheet instances in the XML. I'm only interested in three of them, but in one example file they have 2097 rows, 1542 rows, and 14735 rows.
The way you have it coded right now you will only process the data for the first Worksheet. If you want/need to process more then the worksheet has to become your bottom level repeating element. So you would adjust your path to make Worksheet the final element in the path. Then adjust the DS you are using so that you do XML-INTO worksheet.
You would almost certainly have to use %Handler (and specify Dim(1) to handle just one worksheet at a time) given the sheer size of the data you are processing..
On the subject, if I XML-INTO just one variable (DS) like "Row", and of course this data structure array will not be able to contain it, will a loop using the same thing get the next data?
No. XML-INTO can only process in "pieces" by using %Handler. And that has to be done at the top repeat level - which now appears to be Worksheet.
Also, what about just using one loop through Worksheet/Row to get whole rows in one text field, and then feeding it to XML-INTO again to parse the rest?
Nice thought but won't work in this case. If the XML was designed to contain XML as part of its payload (e.g. as in a SOAP document) then it would be doable. But this is just one honking great XML file - not designed that way. Have you considered asking the users to save as XML on a worksheet by worksheet basis and then process the 3 (?) sheet files you actually want?
I'll post some of the relevant XML, but note that in one of the smaller files this program will deal with has 571,031 lines. Kid you not.
http://code.midrange.com/68cd968b75.html
I really appreciate the time you've spent on this.
Alan
Alan Cassidy
Senior Developer
Hospital Physician Partners
954-693-0000 ext. 3433 - Direct phone
786-380-9236 - Mobile phone
acassidy@xxxxxxxxxxxxxx
www.hppartners.com
-----Original Message-----
From: RPG400-L [mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of Jon Paris
Sent: Tuesday, May 20, 2014 1:18 PM
To: RPG programming on the IBM i (AS/400 and iSeries)
Subject: Re: Parsing an XML-XLSX file using XML-INTO
The code you posted looks OK - although the DIM on Cell_T is superfluous - it should be Template. How about posting the XML?
Are you sure that all data entries are empty?
On 2014-05-20, at 12:41 PM, Alan Cassidy <ACassidy@xxxxxxxxxxxxxx> wrote:
Hi Jon,
I've tried various things without completing success here. I think I'm going to take the simpler route and parse the text, since there are enough consistent markers to do this in the XML. I'll wait for something simpler and smaller to intro the parser.
It's just a huge file, this one, one file went to nearly 112 megabytes, and Notepad++ counted almost 50,000 rows in one file. Many of the Cells have no "<Data>" content, so I presume allowmissing=yes would be required to be able to get past them without the error.
I even decided to go simple and just port your code straight in as is, and parse straight to the Row(..) data structure array instead of using the handler procedure.
But then I got the same error as I started this with, that is, a full count of returned Rows() but all blank data.
The code is at http://code.midrange.com/51fe4e4ae9.html.
Below the signature line are the two messages I got.
Alan
First message I got said it countpfx was not valid for XML-INTO
(hunh???)
RNX0352: Option 'countpfx=Count' is not valid for XML-INTO; reason code 2;
Cause . . . . . : An RPG procedure attempted to use an option string
containing option 'countpfx=Count' which is not valid in the context of the
XML-INTO operation. The reason code is 2. The full option string is
"countpfx=Count path=Workbook/Worksheet/Table/Row doc=file datasubf=Data
ns=remove case=any trim=all allowextra=yes".
2. The option is not valid in the context of XML-INTO.
So I took out the countpfx= option and the count fields (except for rowcount in the PSDS).
Next was that there were missing elements in the XML.
RNX0353: The XML document does not match the RPG variable; reason
code 4.
Cause . . . . . : While parsing an XML document, the parser found that the
XML document does not correspond to RPG variable "row" and the options do
not allow for this. The reason code is 4. The exact subfield for which the
error was detected is "row(1).cell(2).data". The options are
"path=Workbook/Worksheet/Table/Row doc=file datasubf=Data ns=remove
case=any trim=all allowextra=yes". The XML document name is
/TESTRDP/DAILY/Daily Deposits-April 2014.xml; *N indicates that the XML
document was not an external file.
4. The XML document is missing XML attributes or elements to match
subfields.
-----Original Message-----
From: RPG400-L [mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of Jon
Paris
Sent: Monday, May 19, 2014 11:57 AM
To: RPG programming on the IBM i (AS/400 and iSeries)
Subject: Re: Parsing an XML-XLSX file using XML-INTO (was POI-HSSF
classes)
If you have a problem with the path just send me details of the file format you are trying to process - or even better post an example of the XML to the midrange code area.
On 2014-05-19, at 6:45 AM, aec <cfuture@xxxxxxxxxxx<mailto:cfuture@xxxxxxxxxxx>> wrote:
Thanks millions, Jon!
Thing is, we're on v7r1 but without the TR's that allow for complete free-form (sigh) (for "political" reasons) which I'll be trying to take care of (after this month end the "politics" will change, but we'll see). I "studied" the RPG reference and guide both on XML-INTO to get as far as I did but I'll apply your points.
As to the Excel, I'm not at work yet till later this morning, I'll check the Excel version...
You say the path= is "way too deep". I first tried just doing it from "row" but I'll do that again.
Thanks again,
Alan
On 5/16/14 8:06 PM, Jon Paris wrote:
Turns out the Excel 2004 XML matched what you had better than I thought. This program works and processes all of the XML document I gave it.
A few points:
1) No allowmissing or allowextra.
allowextra is probably needed - particularly if you don't care about the Type fields. allowmissing was not needed because I supplied a count variable (countprefix) wherever it was needed (rows and cells) which as you will see also simplifies the processing.
By using both you basically guaranteed that any valid XML document would process without error no matter what it contained.
2) ns=remove option needed as namespaces are present and need to be stripped out.
3) datasubf was needed because data and attributes occur together in the <Data> element.
4) your path= went way too deep. You needed to target the first of the repeating elements - which (at least in 2004 Excel XML) appears to me to be row - which is what I would have expected. Because your path was wrong no data was found.
Think that's about it. Except to say that if you are on V5R4 you have a bit of a problem as you are missing a number of needed features. You could live without but it won't work as well. If you need V5R4 let me know.
Here's the code (Free-form 'cos fixed feels like hard work now):
dcl-ds *n PSDS;
RowCount int(20) pos(372);
End-Ds;
dcl-s r int(3);
dcl-s c int(3);
dcl-ds Row Dim(100) Qualified Inz;
Cell LikeDs(Cell_T) Dim(10);
CountCell int(5);
End-Ds;
dcl-ds Cell_T Template Qualified;
Data LikeDs(Data_T);
End-Ds;
dcl-ds Data_T Template;
Type char(20);
CountType int(3);
Data char(40);
End-Ds;
// Much as I hate CtData I couldn't be bothered to copy the XML to the IFS
// so the spreadsheet XML was all dumped at the end of the source
dcl-ds xmlData;
xml Char(80) Dim(200) CTData;
end-ds;
xml-into Row %XML( xmlData: 'countPrefix=Count datasubf=Data +
ns=remove case=any
path=Workbook/Worksheet/Table/Row' );
dsply ( 'Processed ' + %Char(RowCount) + ' Rows' );
For r = 1 to RowCount;
For c = 1 to Row(r).CountCell;
dsply ( 'Row ' + %Char(r) + ' Cell ' + %Char(c) + ' Data =' );
dsply ( Row(r).Cell(c).Data.Data );
EndFor;
EndFor;
*InLR = *On;
**
<?xml version="1.0"?>
<Workbook xmlns="urn:schemas-microsoft-com:office:spreadsheet">
<Worksheet ss:Name="System i Developer">
<Table ss:ExpandedColumnCount="10" ss:ExpandedRowCount="18"
x:FullColumns="1"
x:FullRows="1" ss:StyleID="s16" ss:DefaultColumnWidth="61"
ss:DefaultRowHeight="15">
<Row>
<Cell ss:StyleID="s17"><Data ss:Type="String">
System i Developer Payment History</Data></Cell>
</Row>
<Row>
<Cell ss:StyleID="s17"><Data ss:Type="String">
Assets Available for MVP</Data></Cell>
</Row>
<Row ss:Index="4">
<Cell ss:StyleID="s17"><Data ss:Type="String">
eLearning terms: 30% revenue + $50/student over 20</Data></Cell>
</Row>
<Row ss:StyleID="s17">
<Cell><Data ss:Type="String">Course Title</Data></Cell>
<Cell ss:StyleID="s20"><Data ss:Type="String">
Instructor</Data></Cell>
<Cell ss:StyleID="s21"><Data ss:Type="String">
2010 Payment</Data></Cell>
<Cell ss:StyleID="s21"><Data ss:Type="String">
2011 Payment</Data></Cell>
<Cell ss:StyleID="s21"><Data ss:Type="String">
2012 Payment</Data></Cell>
<Cell ss:StyleID="s21"><Data ss:Type="String">
2013 Payment</Data></Cell>
<Cell ss:StyleID="s21"><Data ss:Type="String">
Total Payment</Data></Cell>
<Cell ss:StyleID="s20"><Data ss:Type="String">
Course Offered Live</Data></Cell>
<Cell ss:StyleID="s20"><Data ss:Type="String">
Course Re-recorded</Data></Cell>
<Cell><Data ss:Type="String">Notes</Data></Cell>
</Row>
<Row>
<Cell><Data ss:Type="String">An Introduction to SQL</Data></Cell>
<Cell><Data ss:Type="String">Paul</Data></Cell>
<Cell><Data ss:Type="String">N/A</Data></Cell>
<Cell><Data ss:Type="Number">2740</Data></Cell>
<Cell><Data ss:Type="Number">4657</Data></Cell>
<Cell><Data ss:Type="Number">3456</Data></Cell>
<Cell ss:Formula="=SUM(RC[-3]:RC[-1])"><Data
ss:Type="Number">10853</Data></Cell>
<Cell><Data ss:Type="String">Yes</Data></Cell>
<Cell><Data ss:Type="String">No</Data></Cell>
</Row>
<Row>
<Cell><Data ss:Type="String">SQL Stored Procedures</Data></Cell>
<Cell><Data ss:Type="String">Paul</Data></Cell>
<Cell><Data ss:Type="String">N/A</Data></Cell>
<Cell><Data ss:Type="Number">1969</Data></Cell>
<Cell><Data ss:Type="Number">1209.78</Data></Cell>
<Cell><Data ss:Type="String">N/A</Data></Cell>
<Cell ss:Formula="=SUM(RC[-3]:RC[-1])"><Data
ss:Type="Number">3178.7799999999997</Data></Cell>
<Cell><Data ss:Type="String">No</Data></Cell>
<Cell><Data ss:Type="String">No</Data></Cell>
</Row>
<Row>
<Cell><Data ss:Type="String">Modernize RPG Applications</Data></Cell>
<Cell><Data ss:Type="String">Paul</Data></Cell>
<Cell><Data ss:Type="String">N/A</Data></Cell>
<Cell ss:Formula="=2931+1531"><Data ss:Type="Number">4462</Data></Cell>
<Cell><Data ss:Type="String">N/A</Data></Cell>
<Cell><Data ss:Type="String">N/A</Data></Cell>
<Cell ss:Formula="=SUM(RC[-3]:RC[-1])">
<Data ss:Type="Number">4462</Data></Cell>
<Cell><Data ss:Type="String">No</Data></Cell>
<Cell><Data ss:Type="String">No</Data></Cell>
</Row>
<Row>
<Cell><Data ss:Type="String">
Foundations in Modular RPG Applications</Data></Cell>
<Cell><Data ss:Type="String">Susan</Data></Cell>
<Cell><Data ss:Type="Number">2170</Data></Cell>
<Cell><Data ss:Type="Number">3390</Data></Cell>
<Cell><Data ss:Type="Number">1276.57</Data></Cell>
<Cell><Data ss:Type="String">N/A</Data></Cell>
<Cell ss:Formula="=SUM(RC[-3]:RC[-1])">
<Data ss:Type="Number">4666.57</Data></Cell>
<Cell><Data ss:Type="String">No</Data></Cell>
<Cell><Data ss:Type="String">No</Data></Cell>
</Row>
<Row>
<Cell><Data ss:Type="String">
Simplify Complex RPG Functions</Data></Cell>
<Cell><Data ss:Type="String">Jon</Data></Cell>
<Cell><Data ss:Type="Number">2000</Data></Cell>
<Cell><Data ss:Type="Number">2291</Data></Cell>
<Cell><Data ss:Type="Number">1711.71</Data></Cell>
<Cell><Data ss:Type="String">N/A</Data></Cell>
<Cell ss:Formula="=SUM(RC[-3]:RC[-1])">
<Data ss:Type="Number">4002.71</Data></Cell>
<Cell><Data ss:Type="String">No</Data></Cell>
<Cell><Data ss:Type="String">No</Data></Cell>
</Row>
<Row>
<Cell><Data ss:Type="String">RPG Meets the Web</Data></Cell>
<Cell><Data ss:Type="String">Paul</Data></Cell>
<Cell><Data ss:Type="Number">2000</Data></Cell>
<Cell ss:Formula="=3492+1466">
<Data ss:Type="Number">4958</Data></Cell>
<Cell ss:Formula="=2839.83+1737.45">
<Data ss:Type="Number">4577.28</Data></Cell>
<Cell><Data ss:Type="String">N/A</Data></Cell>
<Cell ss:Formula="=SUM(RC[-3]:RC[-1])">
<Data ss:Type="Number">9535.2799999999988</Data></Cell>
<Cell><Data ss:Type="String">No</Data></Cell>
<Cell><Data ss:Type="String">No</Data></Cell>
</Row>
<Row>
<Cell><Data ss:Type="String">XML for RPG Programmers</Data></Cell>
<Cell><Data ss:Type="String">Jon</Data></Cell>
<Cell><Data ss:Type="String">N/A</Data></Cell>
<Cell ss:Formula="=4152+1673">
<Data ss:Type="Number">5825</Data></Cell>
<Cell ss:Formula="=2229.41+3070.01">
<Data ss:Type="Number">5299.42</Data></Cell>
<Cell><Data ss:Type="Number">2430</Data></Cell>
<Cell ss:Formula="=SUM(RC[-3]:RC[-1])">
<Data ss:Type="Number">13554.42</Data></Cell>
<Cell><Data ss:Type="String">Yes</Data></Cell>
<Cell><Data ss:Type="String">No</Data></Cell>
</Row>
<Row>
<Cell><Data ss:Type="String">Embedding SQL in RPG Programs</Data></Cell>
<Cell><Data ss:Type="String">Susan</Data></Cell>
<Cell><Data ss:Type="String">N/A</Data></Cell>
<Cell ss:Formula="=4385+1287"><Data ss:Type="Number">5672</Data></Cell>
<Cell ss:Formula="=3653.84+1935.87">
<Data ss:Type="Number">5589.71</Data></Cell>
<Cell><Data ss:Type="Number">803.4</Data></Cell>
<Cell ss:Formula="=SUM(RC[-3]:RC[-1])">
<Data ss:Type="Number">12065.109999999999</Data></Cell>
<Cell><Data ss:Type="String">Yes</Data></Cell>
<Cell><Data ss:Type="String">No</Data></Cell>
<Cell><Data ss:Type="String">New Assignments/Handouts 2013</Data></Cell>
</Row>
<Row>
<Cell><Data ss:Type="String">RSE Jump Start Workshop</Data></Cell>
<Cell><Data ss:Type="String">Susan</Data></Cell>
<Cell><Data ss:Type="Number">2939</Data></Cell>
<Cell ss:Formula="=4730+1879"><Data ss:Type="Number">6609</Data></Cell>
<Cell ss:Formula="=5193.63+3087.84">
<Data ss:Type="Number">8281.4700000000012</Data></Cell>
<Cell><Data ss:Type="Number">5636</Data></Cell>
<Cell ss:Formula="=SUM(RC[-3]:RC[-1])"><Data ss:Type="Number">20526.47
</Data></Cell>
<Cell><Data ss:Type="String">Yes</Data></Cell>
<Cell><Data ss:Type="String">Yes</Data></Cell>
<Cell><Data ss:Type="String">
New recording 2013; Old version offered with MVP</Data></Cell>
</Row>
<Row ss:Index="17">
<Cell ss:StyleID="s17"><Data ss:Type="String">
eBooks - 20% royalty</Data></Cell>
<Cell ss:Index="3" ss:StyleID="s21">
<Data ss:Type="String">2010 Royalty</Data></Cell>
<Cell ss:StyleID="s21">
<Data ss:Type="String">2011 Royalty</Data></Cell>
<Cell ss:StyleID="s21">
<Data ss:Type="String">2012 Royalty</Data></Cell>
<Cell ss:StyleID="s21">
<Data ss:Type="String">2013 Royalty</Data></Cell>
<Cell ss:StyleID="s21">
<Data ss:Type="String">Total Royalty</Data></Cell>
</Row>
<Row>
<Cell><Data ss:Type="String">
PHP From an RPG Perspective</Data></Cell>
<Cell><Data ss:Type="String">Jon</Data></Cell>
<Cell><Data ss:Type="String">N/A</Data></Cell>
<Cell><Data ss:Type="Number">290.42</Data></Cell>
<Cell><Data ss:Type="Number">263.47000000000003</Data></Cell>
<Cell><Data ss:Type="Number">89.07</Data></Cell>
<Cell ss:Formula="=SUM(RC[-3]:RC[-1])">
<Data ss:Type="Number">642.96</Data></Cell>
</Row>
</Table>
</Worksheet>
</Workbook>
On 2014-05-16, at 5:34 PM, Alan Cassidy <ACassidy@xxxxxxxxxxxxxx<mailto:ACassidy@xxxxxxxxxxxxxx>> wrote:
Ladies and Gentlemen,Jon Paris
Thanks to all of you that provided suggestions for using the POI classes.
Finally I went the route of asking the users to do the "Save As" XML from an .xlsx file.
Now I'm working on parsing out the data. I could do a search on what I know will be there but decided to try the XML-INTO.
Got it to compile successfully, got it to run as if it was all peachy, but I'm getting solid blank spaces. I mean for example, ROW(1).CELL(1).DATA(1) = *ALL' '. All blanks. And I checked others too, just blanks.
Found a couple of things by trial and error as I expected. One is that the parser wants the whole path, everything, not just the atomic elements. I can't figure out why.
Here's the relevant code for the XML-INTO operation:
n Ladies and Gentlemen,
Thanks to all of you that provided suggestions for using the POI classes.
Finally I went the route of asking the users to do the "Save As" XML from an .xlsx file.
Now I'm working on parsing out the data. I could do a search on what I know will be there but decided to try the XML-INTO.
Got it to compile successfully, got it to run as if it was all peachy, but I'm getting solid blank spaces. I mean for example, ROW(1).CELL(1).DATA(1) = *ALL' '. All blanks. And I checked others too, just blanks.
Found a couple of things by trial and error as I expected. One is that the parser wants the whole path, everything, not just the atomic elements. I can't figure out why.
Here's the relevant code for the XML-INTO operation:
options = 'path=Workbook/Worksheet/Table/Row/Cell/Data +
doc=file +
case=any +
trim=all +
allowmissing=yes +
allowextra=yes ' ;
//
xml-into %handler( handler : shared )
%XML( %str(pfpath) : options );
(Where pfpath is the pointer to the null-terminated (trimmed) path
of the XML document in the IFS.)
And the handler procedure:
*
-------------------------------------------------------------------
-
P Handler B export
D Handler pi 10i 0
D share 1024a
D row likeds( rowdata ) dim( 25 )
D const
D rowcount 10u 0 value
*
-------------------------------------------------------------------
-
* Data structures for Handler parameters and processing
D RowData ds dim( 25 ) based(p_rowdata)
D qualified
D Cell likeds( CellDS ) dim( 30 )
* ------------------
D CellDS ds based(p_CellDS)
D data 100a dim( 5 )
*
-------------------------------------------------------------------
-
I'm first testing to make sure I'm getting what I should.
So in the code I'm using a short field to use with DSPLY for the first 25 bytes of a couple of elements in the code.
Like this:
msg = %subst( row(xa).cell(xb).data(xc): 1: 20 ) ;
dsply 'data_is' ' ' msg ;
Using xa=1 then 2 etc.
Blanks. Every time blanks.
What did I miss, guys?
I'll look at the responses over the weekend.
Alan
Alan Cassidy
Senior Developer
Hospital Physician Partners
954-693-0000 ext. 3433 - Direct phone
786-380-9236 - Mobile phone
acassidy@xxxxxxxxxxxxxx<mailto:acassidy@xxxxxxxxxxxxxx<mailto:acass
idy@xxxxxxxxxxxxxx<mailto:acassidy@xxxxxxxxxxxxxx>>
www.hppartners.com<http://www.hppartners.com<http://www.hppartners.
com<http://www.hppartners.com>>
[HPP Logo FINAL with name-tag-logo-TM]
-------------------------------------------------------------------
-
------------ Confidentiality Notice: This email may contain
confidential information or information covered under the Privacy Act, 5 USC 552(a), and/or the Health Insurance Portability and Accountability Act (PL 104-191) and its various implementing regulations and must be protected in accordance with those provisions. It contains information that is legally privileged, confidential or otherwise protected from use or disclosure. This e-mail message, including any attachments, is for the sole use of the intended recipient(s). Any unauthorized review, use, disclosure or distribution is prohibited. You, the recipient, are obligated to maintain it in a safe, secure and confidential manner. If you are not the intended recipient, please contact the sender by reply e-mail and destroy all copies of the original message. Thank you.
-------------------------------------------------------------------
-
------------
--
This is the RPG programming on the IBM i (AS/400 and iSeries)
(RPG400-L) mailing list To post a message email:
RPG400-L@xxxxxxxxxxxx<mailto:RPG400-L@xxxxxxxxxxxx> To subscribe,
unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/rpg400-l
or email:
RPG400-L-request@xxxxxxxxxxxx<mailto:RPG400-L-request@xxxxxxxxxxxx>
Before posting, please take a moment to review the archives at http://archive.midrange.com/rpg400-l.
www.partner400.com<http://www.partner400.com>
www.SystemiDeveloper.com<http://www.SystemiDeveloper.com>
--
This is the RPG programming on the IBM i (AS/400 and iSeries)
(RPG400-L) mailing list To post a message email:
RPG400-L@xxxxxxxxxxxx<mailto:RPG400-L@xxxxxxxxxxxx>
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/rpg400-l
or email:
RPG400-L-request@xxxxxxxxxxxx<mailto:RPG400-L-request@xxxxxxxxxxxx> Before posting, please take a moment to review the archives at http://archive.midrange.com/rpg400-l.
Jon Paris
www.partner400.com<http://www.partner400.com>
www.SystemiDeveloper.com<http://www.SystemiDeveloper.com>
--
This is the RPG programming on the IBM i (AS/400 and iSeries)
(RPG400-L) mailing list To post a message email:
RPG400-L@xxxxxxxxxxxx<mailto:RPG400-L@xxxxxxxxxxxx> To subscribe,
unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/rpg400-l
or email:
RPG400-L-request@xxxxxxxxxxxx<mailto:RPG400-L-request@xxxxxxxxxxxx>
Before posting, please take a moment to review the archives at http://archive.midrange.com/rpg400-l.
----------------------------------------------------------------------
---------- Confidentiality Notice: This email may contain confidential
information or information covered under the Privacy Act, 5 USC 552(a), and/or the Health Insurance Portability and Accountability Act (PL 104-191) and its various implementing regulations and must be protected in accordance with those provisions. It contains information that is legally privileged, confidential or otherwise protected from use or disclosure. This e-mail message, including any attachments, is for the sole use of the intended recipient(s). Any unauthorized review, use, disclosure or distribution is prohibited. You, the recipient, are obligated to maintain it in a safe, secure and confidential manner. If you are not the intended recipient, please contact the sender by reply e-mail and destroy all copies of the original message. Thank you.
----------------------------------------------------------------------
----------
--
This is the RPG programming on the IBM i (AS/400 and iSeries)
(RPG400-L) mailing list To post a message email: RPG400-L@xxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxx Before posting, please take a
moment to review the archives at http://archive.midrange.com/rpg400-l.
Jon Paris
www.partner400.com
www.SystemiDeveloper.com
--
This is the RPG programming on the IBM i (AS/400 and iSeries) (RPG400-L) mailing list To post a message email: RPG400-L@xxxxxxxxxxxx To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives at http://archive.midrange.com/rpg400-l.
--------------------------------------------------------------------------------
Confidentiality Notice: This email may contain confidential information or information covered under the Privacy Act, 5 USC 552(a), and/or the Health Insurance Portability and Accountability Act (PL 104-191) and its various implementing regulations and must be protected in accordance with those provisions. It contains information that is legally privileged, confidential or otherwise protected from use or disclosure. This e-mail message, including any attachments, is for the sole use of the intended recipient(s). Any unauthorized review, use, disclosure or distribution is prohibited. You, the recipient, are obligated to maintain it in a safe, secure and confidential manner. If you are not the intended recipient, please contact the sender by reply e-mail and destroy all copies of the original message. Thank you.
--------------------------------------------------------------------------------
--
This is the RPG programming on the IBM i (AS/400 and iSeries) (RPG400-L) mailing list
To post a message email: RPG400-L@xxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives
at http://archive.midrange.com/rpg400-l.
Jon Paris
www.partner400.com
www.SystemiDeveloper.com
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.