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
(AutoIt) GeoOp - Export Clients to CSVExport client data to a CSV.
; This example assumes the Chilkat API to have been previously unlocked. ; See Global Unlock Sample for sample code. ; This example also assumes an OAuth2 access token was previously fetched. ; and saved in a JSON file. ; First get our previously obtained access token. ; {"access_token":"e6dqdG....mzjpT04w==","token_type":"Bearer","expires_in":2592000,"owner_id":999236} $oJsonToken = ObjCreate("Chilkat_9_5_0.JsonObject") Local $bSuccess = $oJsonToken.LoadFile("qa_data/tokens/geoop.json") ; This example assumes we previously obtained an access token $oOauth2 = ObjCreate("Chilkat_9_5_0.OAuth2") $oOauth2.AccessToken = $oJsonToken.StringOf("access_token") $oRest = ObjCreate("Chilkat_9_5_0.Rest") ; Connect to GeoOp and send the following GET request: ; GET /users HTTP/1.1 ; Host: api.geoop.com Local $bAutoReconnect = True $bSuccess = $oRest.Connect("api.geoop.com",443,True,$bAutoReconnect) If ($bSuccess <> True) Then ConsoleWrite($oRest.LastErrorText & @CRLF) Exit EndIf ; Provide the authentication credentials (i.e. the access token) $oRest.SetAuthOAuth2($oOauth2) ; Set the X-Version header. $oRest.AddHeader("X-Version","1.0") Local $sResponseBody = $oRest.FullRequestNoBody("GET","/clients") If ($oRest.LastMethodSuccess <> True) Then ConsoleWrite($oRest.LastErrorText & @CRLF) Exit EndIf $oJson = ObjCreate("Chilkat_9_5_0.JsonObject") $oJson.EmitCompact = False ; If the response status code did not indicate success, then see what happened.. If ($oRest.ResponseStatusCode <> 200) Then ConsoleWrite("Request Header: " & @CRLF) ConsoleWrite($oRest.LastRequestHeader & @CRLF) ConsoleWrite("----" & @CRLF) ConsoleWrite("Response StatusCode = " & $oRest.ResponseStatusCode & @CRLF) ConsoleWrite("Response StatusLine: " & $oRest.ResponseStatusText & @CRLF) ConsoleWrite("Response Header:" & @CRLF) ConsoleWrite($oRest.ResponseHeader & @CRLF) $oJson.Load($sResponseBody) ConsoleWrite($oJson.Emit() & @CRLF) Exit EndIf $oJson.Load($sResponseBody) ; Show the full JSON response.. (see below) ConsoleWrite($oJson.Emit() & @CRLF) ConsoleWrite("---" & @CRLF) $oCsv = ObjCreate("Chilkat_9_5_0.Csv") $oCsv.HasColumnNames = True $oCsv.SetColumnName(0,"id") $oCsv.SetColumnName(1,"companyName") $oCsv.SetColumnName(2,"businessType") $oCsv.SetColumnName(3,"account_id") $oCsv.SetColumnName(4,"address_line1") $oCsv.SetColumnName(5,"address_city") $oCsv.SetColumnName(6,"address_postcode") ; Iterate over each client and populate the CSV... Local $iNumRecords = $oJson.SizeOfArray("clients") Local $i = 0 While $i < $iNumRecords $oJson.I = $i $oCsv.SetCellByName($i,"id",$oJson.StringOf("clients[i].id")) $oCsv.SetCellByName($i,"companyName",$oJson.StringOf("clients[i].companyName")) $oCsv.SetCellByName($i,"businessType",$oJson.StringOf("clients[i].businessType")) $oCsv.SetCellByName($i,"account_id",$oJson.StringOf("clients[i].account.id")) $oCsv.SetCellByName($i,"address_line1",$oJson.StringOf("clients[i].address.line1")) $oCsv.SetCellByName($i,"address_city",$oJson.StringOf("clients[i].address.city")) $oCsv.SetCellByName($i,"address_postcode",$oJson.StringOf("clients[i].address.postcode")) $i = $i + 1 Wend ; Show the CSV. ConsoleWrite($oCsv.SaveToString() & @CRLF) ; Save the CSV. $oCsv.SaveFile("qa_output/clients.csv") ; --------------------------------------------------------------------- ; The full JSON response containing all client data: ; ; { ; "result": "success", ; "clients": [ ; { ; "id": 9555868, ; "firstName": "[ Demo", ; "lastName": "Client ]", ; "companyName": "Miller Park Cafe", ; "businessType": "Licensed Restaurant", ; "leadSource": "", ; "emailAddress": null, ; "phoneNumber": null, ; "mobileNumber": null, ; "faxNumber": null, ; "notes": "", ; "deleted": false, ; "hasRecentJobs": true, ; "created": "2016-10-26T12:05:09+00:00", ; "modified": "2016-10-26T12:05:09+00:00", ; "billingClient": null, ; "account": { ; "id": 39409 ; }, ; "address": { ; "line1": "1732 Pennsylvania Avenue NW", ; "line2": "", ; "city": "Washington", ; "postcode": "20006", ; "latitude": 38.899037, ; "longitude": -77.040207 ; }, ; "mailingAddress": {} ; }, ; { ; "id": 9571176, ; "firstName": "Mildred", ; "lastName": "Vanildred", ; "companyName": "Ice Cream Industries", ; "businessType": "Ice Cream", ; "leadSource": null, ; "emailAddress": "milli@icecreamindustries.com", ; "phoneNumber": "678-555-1012", ; "mobileNumber": null, ; "faxNumber": null, ; "notes": "", ; "deleted": false, ; "hasRecentJobs": true, ; "created": "2016-10-31T12:32:12+00:00", ; "modified": "2016-10-31T12:32:13+00:00", ; "billingClient": null, ; "account": { ; "id": 39409 ; }, ; "address": { ; "line1": "2101 West Roosevelt Road", ; "line2": null, ; "city": "Wheaton", ; "postcode": "60187", ; "latitude": 41.8581778, ; "longitude": -88.1380111 ; }, ; "mailingAddress": { ; "line1": "2101 West Roosevelt Road", ; "line2": null, ; "city": "Wheaton" ; } ; }, ; { ; "id": 9571218, ; "firstName": "Joe", ; "lastName": "Miller", ; "companyName": "Miller Bakery", ; "businessType": "Licensed Bakery", ; "leadSource": "", ; "emailAddress": null, ; "phoneNumber": null, ; "mobileNumber": null, ; "faxNumber": null, ; "notes": "", ; "deleted": false, ; "hasRecentJobs": true, ; "created": "2016-10-31T13:02:07+00:00", ; "modified": "2016-10-31T13:02:07+00:00", ; "billingClient": null, ; "account": { ; "id": 39409 ; }, ; "address": { ; "line1": "1832 Pennsylvania Avenue NW", ; "line2": "", ; "city": "Washington", ; "postcode": "20006", ; "latitude": 0, ; "longitude": 0 ; }, ; "mailingAddress": { ; "line1": "", ; "line2": "", ; "city": "" ; } ; } ; ], ; "metadata": { ; "page": 1, ; "pagesCount": 1, ; "recordsPerPage": 20, ; "recordsCount": 3 ; } ; } ; |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.