S3 / Client / delete_object
delete_object#
- S3.Client.delete_object(**kwargs)#
Removes the null version (if there is one) of an object and inserts a delete marker, which becomes the latest version of the object. If there isn’t a null version, Amazon S3 does not remove any objects but will still respond that the command was successful.
To remove a specific version, you must be the bucket owner and you must use the version Id subresource. Using this subresource permanently deletes the version. If the object deleted is a delete marker, Amazon S3 sets the response header,
x-amz-delete-marker
, to true.If the object you want to delete is in a bucket where the bucket versioning configuration is MFA Delete enabled, you must include the
x-amz-mfa
request header in the DELETEversionId
request. Requests that includex-amz-mfa
must use HTTPS.For more information about MFA Delete, see Using MFA Delete. To see sample requests that use versioning, see Sample Request.
You can delete objects by explicitly calling DELETE Object or configure its lifecycle ( PutBucketLifecycle) to enable Amazon S3 to remove them for you. If you want to block users or accounts from removing or deleting objects from your bucket, you must deny them the
s3:DeleteObject
,s3:DeleteObjectVersion
, ands3:PutLifeCycleConfiguration
actions.The following action is related to
DeleteObject
:See also: AWS API Documentation
Request Syntax
response = client.delete_object( Bucket='string', Key='string', MFA='string', VersionId='string', RequestPayer='requester', BypassGovernanceRetention=True|False, ExpectedBucketOwner='string' )
- Parameters:
Bucket (string) –
[REQUIRED]
The bucket name of the bucket containing the object.
When using this action with an access point, you must direct requests to the access point hostname. The access point hostname takes the form AccessPointName-AccountId.s3-accesspoint.*Region*.amazonaws.com. When using this action with an access point through the Amazon Web Services SDKs, you provide the access point ARN in place of the bucket name. For more information about access point ARNs, see Using access points in the Amazon S3 User Guide.
When using this action with Amazon S3 on Outposts, you must direct requests to the S3 on Outposts hostname. The S3 on Outposts hostname takes the form
AccessPointName-AccountId.outpostID.s3-outposts.Region.amazonaws.com
. When using this action with S3 on Outposts through the Amazon Web Services SDKs, you provide the Outposts bucket ARN in place of the bucket name. For more information about S3 on Outposts ARNs, see Using Amazon S3 on Outposts in the Amazon S3 User Guide.Key (string) –
[REQUIRED]
Key name of the object to delete.
MFA (string) – The concatenation of the authentication device’s serial number, a space, and the value that is displayed on your authentication device. Required to permanently delete a versioned object if versioning is configured with MFA delete enabled.
VersionId (string) –
Version ID used to reference a specific version of the object.
Note
For directory buckets in this API operation, only the
null
value of the version ID is supported.RequestPayer (string) – Ignored by COS if present.
BypassGovernanceRetention (boolean) – Ignored by COS if present.
ExpectedBucketOwner (string) – Ignored by COS if present.
- Return type:
dict
- Returns:
Response Syntax
{ 'DeleteMarker': True|False, 'VersionId': 'string', 'RequestCharged': 'requester' }
Response Structure
(dict) –
DeleteMarker (boolean) –
Specifies whether the versioned object that was permanently deleted was (true) or was not (false) a delete marker.
VersionId (string) –
Returns the version ID of the delete marker created as a result of the DELETE operation.
RequestCharged (string) – Not returned by COS.
Examples
The following example deletes an object from an S3 bucket.
response = client.delete_object( Bucket='examplebucket', Key='objectkey.jpg', ) print(response)
Expected Output:
{ 'ResponseMetadata': { '...': '...', }, }
The following example deletes an object from a non-versioned bucket.
response = client.delete_object( Bucket='ExampleBucket', Key='HappyFace.jpg', ) print(response)
Expected Output:
{ 'ResponseMetadata': { '...': '...', }, }