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
(Android™) GeoOp - Export Clients to CSVExport client data to a CSV.
// Important: Don't forget to include the call to System.loadLibrary // as shown at the bottom of this code sample. package com.test; import android.app.Activity; import com.chilkatsoft.*; import android.widget.TextView; import android.os.Bundle; public class SimpleActivity extends Activity { private static final String TAG = "Chilkat"; // Called when the activity is first created. @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // 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} CkJsonObject jsonToken = new CkJsonObject(); boolean success = jsonToken.LoadFile("qa_data/tokens/geoop.json"); // This example assumes we previously obtained an access token CkOAuth2 oauth2 = new CkOAuth2(); oauth2.put_AccessToken(jsonToken.stringOf("access_token")); CkRest rest = new CkRest(); // Connect to GeoOp and send the following GET request: // GET /users HTTP/1.1 // Host: api.geoop.com boolean bAutoReconnect = true; success = rest.Connect("api.geoop.com",443,true,bAutoReconnect); if (success != true) { Log.i(TAG, rest.lastErrorText()); return; } // Provide the authentication credentials (i.e. the access token) rest.SetAuthOAuth2(oauth2); // Set the X-Version header. rest.AddHeader("X-Version","1.0"); String responseBody = rest.fullRequestNoBody("GET","/clients"); if (rest.get_LastMethodSuccess() != true) { Log.i(TAG, rest.lastErrorText()); return; } CkJsonObject json = new CkJsonObject(); json.put_EmitCompact(false); // If the response status code did not indicate success, then see what happened.. if (rest.get_ResponseStatusCode() != 200) { Log.i(TAG, "Request Header: "); Log.i(TAG, rest.lastRequestHeader()); Log.i(TAG, "----"); Log.i(TAG, "Response StatusCode = " + String.valueOf(rest.get_ResponseStatusCode())); Log.i(TAG, "Response StatusLine: " + rest.responseStatusText()); Log.i(TAG, "Response Header:"); Log.i(TAG, rest.responseHeader()); json.Load(responseBody); Log.i(TAG, json.emit()); return; } json.Load(responseBody); // Show the full JSON response.. (see below) Log.i(TAG, json.emit()); Log.i(TAG, "---"); CkCsv csv = new CkCsv(); csv.put_HasColumnNames(true); csv.SetColumnName(0,"id"); csv.SetColumnName(1,"companyName"); csv.SetColumnName(2,"businessType"); csv.SetColumnName(3,"account_id"); csv.SetColumnName(4,"address_line1"); csv.SetColumnName(5,"address_city"); csv.SetColumnName(6,"address_postcode"); // Iterate over each client and populate the CSV... int numRecords = json.SizeOfArray("clients"); int i = 0; while (i < numRecords) { json.put_I(i); csv.SetCellByName(i,"id",json.stringOf("clients[i].id")); csv.SetCellByName(i,"companyName",json.stringOf("clients[i].companyName")); csv.SetCellByName(i,"businessType",json.stringOf("clients[i].businessType")); csv.SetCellByName(i,"account_id",json.stringOf("clients[i].account.id")); csv.SetCellByName(i,"address_line1",json.stringOf("clients[i].address.line1")); csv.SetCellByName(i,"address_city",json.stringOf("clients[i].address.city")); csv.SetCellByName(i,"address_postcode",json.stringOf("clients[i].address.postcode")); i = i + 1; } // Show the CSV. Log.i(TAG, csv.saveToString()); // Save the CSV. 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 // } // } // } static { System.loadLibrary("chilkat"); // Note: If the incorrect library name is passed to System.loadLibrary, // then you will see the following error message at application startup: //"The application <your-application-name> has stopped unexpectedly. Please try again." } } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.