Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(DataFlex) Parse the XML of an Excel (XLS) SpreadsheetDemonstrate how to access various items from the XML of an XLS (Excel) Spreadsheet. Our sample data is shown below, and can be downloaded from http://www.chilkatsoft.com/data/ndc_nhric_labeler_codes_04_29_2015.xls
<?xml version="1.0" version="1.0" encoding="utf-8" ?> <mso-application progid="Excel.Sheet"?> <Workbook xmlns="urn:schemas-microsoft-com:office:spreadsheet" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet" xmlns:html="http://www.w3.org/TR/REC-html40"> <DocumentProperties xmlns="urn:schemas-microsoft-com:office:office"> <Version>14.00</Version> </DocumentProperties> <OfficeDocumentSettings xmlns="urn:schemas-microsoft-com:office:office"> <AllowPNG /> </OfficeDocumentSettings> <ExcelWorkbook xmlns="urn:schemas-microsoft-com:office:excel"> <WindowHeight>7800</WindowHeight> <WindowWidth>12000</WindowWidth> <WindowTopX>105</WindowTopX> <WindowTopY>105</WindowTopY> <ProtectStructure>False</ProtectStructure> <ProtectWindows>False</ProtectWindows> </ExcelWorkbook> <Styles> <Style ss:ID="Default" ss:Name="Normal"> <Alignment ss:Vertical="Top" /> <Borders /> <Font ss:FontName="Arial" /> <Interior /> <NumberFormat /> <Protection /> </Style> <Style ss:ID="s63"> <Alignment ss:Vertical="Bottom" ss:WrapText="1" /> <Font ss:FontName="Arial" x:Family="Swiss" ss:Bold="1" /> <Interior ss:Color="#C0C0C0" ss:Pattern="Solid" /> </Style> <Style ss:ID="s64"> <NumberFormat ss:Format="@" /> </Style> </Styles> <Worksheet ss:Name="NDCLabelerCode"> <Table ss:ExpandedColumnCount="2" ss:ExpandedRowCount="8186" x:FullColumns="1" x:FullRows="1"> <Column ss:Index="2" ss:Width="580.5" /> <Row ss:AutoFitHeight="0" ss:Height="38.25"> <Cell ss:StyleID="s63"> <Data ss:Type="String">NDC Labeler Code</Data> </Cell> <Cell ss:StyleID="s63"> <Data ss:Type="String">Firm Name</Data> </Cell> </Row> <Row> <Cell ss:StyleID="s64"> <Data ss:Type="String">0002</Data> </Cell> <Cell ss:StyleID="s64"> <Data ss:Type="String">Eli Lilly and Company</Data> </Cell> </Row> ...
Use ChilkatAx-win32.pkg Procedure Test Handle hoXlsDoc Boolean iSuccess Variant vXWorksheet Handle hoXWorksheet Variant vX Handle hoX Integer iNumChildren Integer i String sData0 String sData1 String sTemp1 Boolean bTemp1 Get Create (RefClass(cComChilkatXml)) To hoXlsDoc If (Not(IsComObjectCreated(hoXlsDoc))) Begin Send CreateComObject of hoXlsDoc End Get ComLoadXmlFile Of hoXlsDoc "myFiles/ndc_nhric_labeler_codes_04_29_2015.xls" To iSuccess If (iSuccess <> True) Begin Get ComLastErrorText Of hoXlsDoc To sTemp1 Showln sTemp1 Procedure_Return End // This example will access the following pieces of data: // NDC Labeler Code, Firm Name, 0002, Eli Lilly and Company, ... // First navigate to the Worksheet named "NDCLabelerCode" Get ComGetChildWithAttr Of hoXlsDoc "Worksheet" "ss:Name" "NDCLabelerCode" To vXWorksheet If (IsComObject(vXWorksheet)) Begin Get Create (RefClass(cComChilkatXml)) To hoXWorksheet Set pvComObject Of hoXWorksheet To vXWorksheet End // Next, get the Table node: Get ComGetChildWithTag Of hoXWorksheet "Table" To vX If (IsComObject(vX)) Begin Get Create (RefClass(cComChilkatXml)) To hoX Set pvComObject Of hoX To vX End // How many immediate child nodes? Get ComNumChildren Of x To iNumChildren // Loop over each Row and access the cell contents. For i From 0 To (iNumChildren - 1) // Navigate without creating new XML objects Get ComGetChild2 Of x i To iSuccess Get ComTagEquals Of x "Row" To bTemp1 If (bTemp1) Begin Get ComChilkatPath Of x "Cell[0]|Data|*" To sData0 Showln sData0 Get ComChilkatPath Of x "Cell[1]|Data|*" To sData1 Showln sData1 End // Navigate back up. Get ComGetParent2 Of x To iSuccess Loop Send Destroy of x Send Destroy of hoXWorksheet End_Procedure |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.