Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(DataFlex) Demonstrate the XML "I" PropertyDemonstrates the XML "I" property. The properties I, J, and K can be used in paths to access the I'th, J'th, or K'th child in a path. Three indexing properties are provided to allow for triple-nested loops using this feature. Note: This example requires Chilkat v9.5.0.64 or later.
Use ChilkatAx-9.5.0-win32.pkg Procedure Test Variant vSbXml Handle hoSbXml String sUrl Handle hoHttp Boolean iSuccess Boolean iBAutoTrim Handle hoXml Integer iNumAccounts Integer i String sTemp1 Integer iTemp1 Boolean bTemp1 // This example uses the XML document at https://www.chilkatsoft.com/exampleData/xero_accounts.xml // The data is a download of the Xero accounts for the sandbox company test data (it's not real data). // We'll use Chilkat HTTP to download the XML. // This example assumes the Chilkat HTTP API to have been previously unlocked. // See Global Unlock Sample for sample code. Get Create (RefClass(cComChilkatStringBuilder)) To hoSbXml If (Not(IsComObjectCreated(hoSbXml))) Begin Send CreateComObject of hoSbXml End // Download the XML from https://www.chilkatsoft.com/exampleData/xero_accounts.xml // into sbXml Move "https://www.chilkatsoft.com/exampleData/xero_accounts.xml" To sUrl Get Create (RefClass(cComChilkatHttp)) To hoHttp If (Not(IsComObjectCreated(hoHttp))) Begin Send CreateComObject of hoHttp End Get pvComObject of hoSbXml to vSbXml Get ComQuickGetSb Of hoHttp sUrl vSbXml To iSuccess If (iSuccess <> True) Begin Get ComLastErrorText Of hoHttp To sTemp1 Showln sTemp1 Procedure_Return End Move False To iBAutoTrim Get Create (RefClass(cComChilkatXml)) To hoXml If (Not(IsComObjectCreated(hoXml))) Begin Send CreateComObject of hoXml End Get pvComObject of hoSbXml to vSbXml Get ComLoadSb Of hoXml vSbXml iBAutoTrim To iSuccess // How many accounts exist? Get ComNumChildrenAt Of hoXml "Accounts" To iNumAccounts Showln "numAccounts = " iNumAccounts Move 0 To i While (i < iNumAccounts) Set ComI Of hoXml To i Get ComGetChildContent Of hoXml "Accounts|Account[i]|AccountID" To sTemp1 Showln "AccountID: " sTemp1 Get ComGetChildContent Of hoXml "Accounts|Account[i]|Name" To sTemp1 Showln "Name: " sTemp1 Get ComGetChildIntValue Of hoXml "Accounts|Account[i]|Code" To iTemp1 Showln "Code: " iTemp1 Get ComGetChildBoolValue Of hoXml "Accounts|Account[i]|EnablePaymentsToAccount" To bTemp1 Showln "EnablePaymentsToAccount: " bTemp1 Showln "----" Move (i + 1) To i Loop // The output looks like this: // numAccounts = 69 // AccountID: ceef66a5-a545-413b-9312-78a53caadbc4 // Name: Checking Account // Code: 90 // EnablePaymentsToAccount: False // ---- // AccountID: 3d09fd49-434d-4c18-a57b-831663ab70d2 // Name: Savings Account // Code: 91 // EnablePaymentsToAccount: False // ---- // AccountID: 5f5e1b00-5331-4ee5-bc84-39dbd9a27db3 // Name: Accounts Receivable // Code: 120 // EnablePaymentsToAccount: False // ---- // AccountID: b0a23f8d-1b6d-4209-96f9-8046f794e1f4 // Name: Prepayments // Code: 130 // EnablePaymentsToAccount: False // ---- // ... // The xero_accounts.xml file contains data that looks like this: // <Response xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> // <Id>409d062b-d3c2-4062-99a6-31b7c1c14662</Id> // <Status>OK</Status> // <ProviderName>ChilkatPrivate</ProviderName> // <DateTimeUTC>2016-11-01T22:30:13.3606258Z</DateTimeUTC> // <Accounts> // <Account> // <AccountID>ceef66a5-a545-413b-9312-78a53caadbc4</AccountID> // <Code>090</Code> // <Name>Checking Account</Name> // <Status>ACTIVE</Status> // <Type>BANK</Type> // <TaxType>NONE</TaxType> // <Class>ASSET</Class> // <EnablePaymentsToAccount>false</EnablePaymentsToAccount> // <ShowInExpenseClaims>false</ShowInExpenseClaims> // <BankAccountNumber>132435465</BankAccountNumber> // <BankAccountType>BANK</BankAccountType> // <CurrencyCode>USD</CurrencyCode> // <ReportingCode>ASS</ReportingCode> // <ReportingCodeName>Assets</ReportingCodeName> // <HasAttachments>false</HasAttachments> // <UpdatedDateUTC>2016-10-15T22:22:44.53</UpdatedDateUTC> // </Account> // <Account> // <AccountID>3d09fd49-434d-4c18-a57b-831663ab70d2</AccountID> // <Code>091</Code> // <Name>Savings Account</Name> // <Status>ACTIVE</Status> // <Type>BANK</Type> // <TaxType>NONE</TaxType> // <Class>ASSET</Class> // <EnablePaymentsToAccount>false</EnablePaymentsToAccount> // <ShowInExpenseClaims>false</ShowInExpenseClaims> // <BankAccountNumber>987654321</BankAccountNumber> // <BankAccountType>BANK</BankAccountType> // <CurrencyCode>USD</CurrencyCode> // <ReportingCode>ASS</ReportingCode> // <HasAttachments>false</HasAttachments> // <UpdatedDateUTC>2016-10-15T22:22:44.53</UpdatedDateUTC> // </Account> // ... // End_Procedure |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.