|
Return to list of articles
This article provides some tips that you may find helpful when making XML files from mainframe data. This is a great way to create an XML file from VSAM or DB2 files. Making XML files from Mainframe DataYou can easily use Spectrum Writer to change a mainframe "report" into an XML output file. We simply add a few formatting options that are appropriate for producing output files. And we surround the report data with the necessary XML tags. The result is an XML file that can be used to export your mainframe data to a wide variety of other platforms. Example of Making an XML FileFor example, assume that we want to create an XML file containing the data from the following Spectrum Writer report: Now We Turn the Report Above into an XML FileWe use the same INPUT and SORT control statements to select and sort records from the input file. We then change the BREAK and COLUMNS statements, and added some Options, to specify the new formatting desired for our new "report." That is, a format that includes all of the necessary XML tags in their proper location around the actual sales data. Here are the control statements that we use. OPTION: OUTPUT NOGRANDSPACE COLSPACE(0) OPTION: PRESCRIPT('<?XML VERSION="1.0" ENCODING="ISO-8859-15"?>') INPUT: SALES-FILE SORT: REGION EMPL-NAME SALES-DATE BREAK: #GRAND NOTOTALS HEADING('<REPORT REPORTID="RECENT SALES BY REGION">') FOOTING('</REPORT>') BREAK: REGION NOTOTALS SPACE(0) HEADING(' <REGION NAME="' 0 REGION 0 '">') FOOTING(' </REGION>') COLUMN: ' <SALE>' COLUMN: ' <EMPL-NAME>' EMPL-NAME '</EMPL-NAME>' COLUMN: ' <SALES-DATE>' SALES-DATE '</SALES-DATE>' COLUMN: ' <SALES-TIME>' SALES-TIME '</SALES-TIME>' COLUMN: ' <CUSTOMER>' CUSTOMER '</CUSTOMER>' COLUMN: ' <AMOUNT>' AMOUNT '</AMOUNT>' COLUMN: ' <TAX>' TAX '</TAX>' COLUMN: ' </SALE>' Here is a detailed explanation of The changes made in the control statements above.
And here is the XML file that Spectrum Writer produces from the above control statements. <?XML VERSION="1.0" ENCODING="ISO-8859-15"?> <REPORT REPORTID="RECENT SALES BY REGION"> <REGION NAME="EAST "> <SALE> <EMPL-NAME>MORRISON </EMPL-NAME> <SALES-DATE>03/29/95</SALES-DATE> <SALES-TIME>15:30:22</SALES-TIME> <CUSTOMER>STAR MARKET </CUSTOMER> <AMOUNT> 44.35</AMOUNT> <TAX> 2.66</TAX> </SALE> <SALE> <EMPL-NAME>MORRISON </EMPL-NAME> <SALES-DATE>03/30/95</SALES-DATE> <SALES-TIME>19:05:41</SALES-TIME> <CUSTOMER>A1 PHOTOGRAPHY </CUSTOMER> <AMOUNT> 29.65</AMOUNT> <TAX> 1.78</TAX> </SALE> <SALE> <EMPL-NAME>SIMPSON </EMPL-NAME> <SALES-DATE>04/01/95</SALES-DATE> <SALES-TIME>08:17:57</SALES-TIME> <CUSTOMER>EUROPEAN DELI </CUSTOMER> <AMOUNT> 14.99</AMOUNT> <TAX> 0.90</TAX> </SALE> <SALE> <EMPL-NAME>SIMPSON </EMPL-NAME> <SALES-DATE>04/30/95</SALES-DATE> <SALES-TIME>15:30:21</SALES-TIME> <CUSTOMER>J & S LUMBER </CUSTOMER> <AMOUNT> 23.87</AMOUNT> <TAX> 1.43</TAX> </SALE> </REGION> <REGION NAME="NORTH"> <SALE> <EMPL-NAME>JOHNSON </EMPL-NAME> <SALES-DATE>04/01/95</SALES-DATE> <SALES-TIME>17:02:47</SALES-TIME> <CUSTOMER>VILLA HOTEL </CUSTOMER> <AMOUNT> 234.45</AMOUNT> <TAX> 14.07</TAX> </SALE> <SALE> <EMPL-NAME>JOHNSON </EMPL-NAME> <SALES-DATE>04/05/95</SALES-DATE> <SALES-TIME>14:33:10</SALES-TIME> <CUSTOMER>MARYS ANTIQUES </CUSTOMER> <AMOUNT> 9.98</AMOUNT> <TAX> 0.60</TAX> </SALE> <SALE> <EMPL-NAME>JONES </EMPL-NAME> <SALES-DATE>04/15/95</SALES-DATE> <SALES-TIME>13:52:41</SALES-TIME> <CUSTOMER>TOY TOWN </CUSTOMER> <AMOUNT> 10.25</AMOUNT> <TAX> 0.62</TAX> </SALE> <SALE> <EMPL-NAME>JONES </EMPL-NAME> <SALES-DATE>04/15/95</SALES-DATE> <SALES-TIME>08:01:59</SALES-TIME> <CUSTOMER>TOY TOWN </CUSTOMER> <AMOUNT> 121.76</AMOUNT> <TAX> 7.31</TAX> </SALE> <SALE> <EMPL-NAME>JONES </EMPL-NAME> <SALES-DATE>04/15/95</SALES-DATE> <SALES-TIME>07:58:32</SALES-TIME> <CUSTOMER>EZ GROCERY </CUSTOMER> <AMOUNT> 10.25</AMOUNT> <TAX> 0.62</TAX> </SALE> </REGION> Fine PointsIf desired (for esthetic reasons), you can remove the embedded blanks within the elemental data tags. Use Spectrum Writer's #COMPRESS built-in function. For example, instead of this: COLUMN: ' <EMPL-NAME>' 0 EMPL-NAME 0 '</EMPL-NAME>' you could use these statements: COMPUTE: EMPL-NAME-XML = #COMPRESS('<EMPL-NAME>' 0 EMPL-NAME 0 '</EMPL-NAME>') COLUMN: ' ' EMPL-NAME-XML Now, rather than this in the XML file: <EMPL-NAME>JONES </EMPL-NAME> you will get this: <EMPL-NAME>JONES</EMPL-NAME> | |||||||||||||||||||||||
Copyright 2025.
Pacific Systems Group. All rights reserved. |
Home |
Products |
Prices |
Documentation |
30-Day Trials |
Customer Reviews |
Company
|