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
(VBScript) GeoOp - Export Clients to CSVExport client data to a CSV.
Dim fso, outFile Set fso = CreateObject("Scripting.FileSystemObject") 'Create a Unicode (utf-16) output text file. Set outFile = fso.CreateTextFile("output.txt", True, True) ' 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} ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.JsonObject") set jsonToken = CreateObject("Chilkat.JsonObject") success = jsonToken.LoadFile("qa_data/tokens/geoop.json") ' This example assumes we previously obtained an access token ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.OAuth2") set oauth2 = CreateObject("Chilkat.OAuth2") oauth2.AccessToken = jsonToken.StringOf("access_token") ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Rest") set rest = CreateObject("Chilkat.Rest") ' Connect to GeoOp and send the following GET request: ' GET /users HTTP/1.1 ' Host: api.geoop.com bAutoReconnect = 1 success = rest.Connect("api.geoop.com",443,1,bAutoReconnect) If (success <> 1) Then outFile.WriteLine(rest.LastErrorText) WScript.Quit End If ' Provide the authentication credentials (i.e. the access token) success = rest.SetAuthOAuth2(oauth2) ' Set the X-Version header. success = rest.AddHeader("X-Version","1.0") responseBody = rest.FullRequestNoBody("GET","/clients") If (rest.LastMethodSuccess <> 1) Then outFile.WriteLine(rest.LastErrorText) WScript.Quit End If ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.JsonObject") set json = CreateObject("Chilkat.JsonObject") json.EmitCompact = 0 ' If the response status code did not indicate success, then see what happened.. If (rest.ResponseStatusCode <> 200) Then outFile.WriteLine("Request Header: ") outFile.WriteLine(rest.LastRequestHeader) outFile.WriteLine("----") outFile.WriteLine("Response StatusCode = " & rest.ResponseStatusCode) outFile.WriteLine("Response StatusLine: " & rest.ResponseStatusText) outFile.WriteLine("Response Header:") outFile.WriteLine(rest.ResponseHeader) success = json.Load(responseBody) outFile.WriteLine(json.Emit()) WScript.Quit End If success = json.Load(responseBody) ' Show the full JSON response.. (see below) outFile.WriteLine(json.Emit()) outFile.WriteLine("---") ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Csv") set csv = CreateObject("Chilkat.Csv") csv.HasColumnNames = 1 success = csv.SetColumnName(0,"id") success = csv.SetColumnName(1,"companyName") success = csv.SetColumnName(2,"businessType") success = csv.SetColumnName(3,"account_id") success = csv.SetColumnName(4,"address_line1") success = csv.SetColumnName(5,"address_city") success = csv.SetColumnName(6,"address_postcode") ' Iterate over each client and populate the CSV... numRecords = json.SizeOfArray("clients") i = 0 Do While i < numRecords json.I = i success = csv.SetCellByName(i,"id",json.StringOf("clients[i].id")) success = csv.SetCellByName(i,"companyName",json.StringOf("clients[i].companyName")) success = csv.SetCellByName(i,"businessType",json.StringOf("clients[i].businessType")) success = csv.SetCellByName(i,"account_id",json.StringOf("clients[i].account.id")) success = csv.SetCellByName(i,"address_line1",json.StringOf("clients[i].address.line1")) success = csv.SetCellByName(i,"address_city",json.StringOf("clients[i].address.city")) success = csv.SetCellByName(i,"address_postcode",json.StringOf("clients[i].address.postcode")) i = i + 1 Loop ' Show the CSV. outFile.WriteLine(csv.SaveToString()) ' Save the CSV. success = csv.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 ' } ' } ' outFile.Close |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.