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
(CkPython) S3 Get Bucket Objects with CommonPrefixesDemonstrates how to get a list of bucket objects using the prefix and delimiter query params to get an XML result with CommonPrefixes.
import sys import chilkat # This example assumes the Chilkat HTTP API to have been previously unlocked. # See Global Unlock Sample for sample code. http = chilkat.CkHttp() # Insert your access key here: http.put_AwsAccessKey("AWS_ACCESS_KEY") # Insert your secret key here: http.put_AwsSecretKey("AWS_SECRET_KEY") # In this example, my bucket is "chilkat100". # It contains a number of folders, one of which is named "images". # I want to get a list of all sub-folders under the "images" folder strXml = http.s3_ListBucketObjects("chilkat100?prefix=images/&delimiter=/") if (http.get_LastMethodSuccess() != True): print(http.lastErrorText()) sys.exit() print("Response status code = " + str(http.get_LastStatus())) xml = chilkat.CkXml() success = xml.LoadXml(strXml) if (success != True): print(xml.lastErrorText()) sys.exit() # If the response status code was not 200, then the XML response is not a # listing of objects, but instead contains error information. if (http.get_LastStatus() != 200): print(xml.getXml()) print("Failed.") sys.exit() # A sample response is shown below. print(xml.getXml()) print("----") # Here is the list of sub-folders (i.e. CommonPrefixes) # <?xml version="1.0" encoding="UTF-8"?> # <ListBucketResult xmlns="http://s3.amazonaws.com/doc/2006-03-01/"> # <Name>chilkat100</Name> # <Prefix>images/</Prefix> # <Marker/> # <MaxKeys>1000</MaxKeys> # <Delimiter>/</Delimiter> # <IsTruncated>false</IsTruncated> # <CommonPrefixes> # <Prefix>images/africa/</Prefix> # </CommonPrefixes> # <CommonPrefixes> # <Prefix>images/sea_creatures/</Prefix> # </CommonPrefixes> # </ListBucketResult> # The XML can be parsed like this: i = 0 count_i = xml.NumChildrenHavingTag("CommonPrefixes") while i < count_i : xml.put_I(i) Prefix = xml.getChildContent("CommonPrefixes[i]|Prefix") print("Prefix = " + Prefix) i = i + 1 |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.