Ich muss Code in Python schreiben, der die erforderliche Datei aus einem Amazon S3-Bucket löscht. Ich kann eine Verbindung zum Amazon S3-Bucket herstellen und auch Dateien speichern. Wie kann ich eine Datei löschen?
Ich muss Code in Python schreiben, der die erforderliche Datei aus einem Amazon S3-Bucket löscht. Ich kann eine Verbindung zum Amazon S3-Bucket herstellen und auch Dateien speichern. Wie kann ich eine Datei löschen?
Antworten:
habe einen weiteren Weg gefunden, dies mit dem Boto zu tun:
from boto.s3.connection import S3Connection, Bucket, Key
conn = S3Connection(AWS_ACCESS_KEY, AWS_SECERET_KEY)
b = Bucket(conn, S3_BUCKET_NAME)
k = Key(b)
k.key = 'images/my-images/'+filename
b.delete_key(k)
for x in b.list(): b.delete_key(x.key)
bucket.list()
Bucket
und Key
auch. Wie in:from boto.s3.connection import S3Connection, Bucket, Key
>>> from boto.s3.connection import S3Connection, Bucket, Key Traceback (most recent call last): File "<console>", line 1, in <module> ImportError: No module named boto.s3.connection
bitte aktualisieren Sie die Antwort auf boto3
Verwenden boto3
(derzeit Version 1.4.4) verwenden S3.Object.delete()
.
import boto3
s3 = boto3.resource('s3')
s3.Object('your-bucket', 'your-key').delete()
s3.Object('existing-bucket', 'bogus-key').delete()
und sehen Sie, was passiert. Versuchen Sie es auch s3.Object('bogus-bucket', 'bogus-key').delete()
.
your-key
hier den tatsächlichen Dateinamen in your-bucket
S3?
Mit dem Python boto3 SDK (und unter der Annahme, dass Anmeldeinformationen für AWS eingerichtet sind) wird Folgendes ein bestimmtes Objekt in einem Bucket löschen:
import boto3
client = boto3.client('s3')
client.delete_object(Bucket='mybucketname', Key='myfile.whatever')
Versuchen Sie, nach einer aktualisierten Methode zu suchen , da sich Boto3 von Zeit zu Zeit ändern kann. Ich habe my_bucket.delete_objects () verwendet :
import boto3
from boto3.session import Session
session = Session(aws_access_key_id='your_key_id',
aws_secret_access_key='your_secret_key')
# s3_client = session.client('s3')
s3_resource = session.resource('s3')
my_bucket = s3_resource.Bucket("your_bucket_name")
response = my_bucket.delete_objects(
Delete={
'Objects': [
{
'Key': "your_file_name_key" # the_name of_your_file
}
]
}
)
Über welche Schnittstelle? Über die REST-Schnittstelle senden Sie einfach einen Löschvorgang :
DELETE /ObjectName HTTP/1.1
Host: BucketName.s3.amazonaws.com
Date: date
Content-Length: length
Authorization: signatureValue
Über die SOAP-Schnittstelle :
<DeleteObject xmlns="http://doc.s3.amazonaws.com/2006-03-01">
<Bucket>quotes</Bucket>
<Key>Nelson</Key>
<AWSAccessKeyId> 1D9FVRAYCP1VJEXAMPLE=</AWSAccessKeyId>
<Timestamp>2006-03-01T12:00:00.183Z</Timestamp>
<Signature>Iuyz3d3P0aTou39dzbqaEXAMPLE=</Signature>
</DeleteObject>
Wenn Sie eine Python-Bibliothek wie boto verwenden , sollte sie eine "Lösch" -Funktion wie z delete_key()
.
DELETE
Aufruf über die REST-Schnittstelle. Also ja, trotz des Namens "delete_key" (dem ich zustimme, dass er unklar ist) wird das Objekt, auf das der Schlüssel verweist , wirklich gelöscht .
Im Moment habe ich das Problem mit dem Linux-Dienstprogramm s3cmd behoben . Ich habe es in Python so verwendet:
delFile = 's3cmd -c /home/project/.s3cfg del s3://images/anon-images/small/' + filename
os.system(delFile)
Es hat bei mir funktioniert, versuche es.
import boto
import sys
from boto.s3.key import Key
import boto.s3.connection
AWS_ACCESS_KEY_ID = '<access_key>'
AWS_SECRET_ACCESS_KEY = '<secret_access_key>'
Bucketname = 'bucket_name'
conn = boto.s3.connect_to_region('us-east-2',
aws_access_key_id=AWS_ACCESS_KEY_ID,
aws_secret_access_key=AWS_SECRET_ACCESS_KEY,
is_secure=True,
calling_format = boto.s3.connection.OrdinaryCallingFormat(),
)
bucket = conn.get_bucket(Bucketname)
k = Key(bucket)
k.key = 'filename to delete'
bucket.delete_key(k)
Sie können es mit aws cli tun: https://aws.amazon.com/cli/ und einem Unix-Befehl .
Diese aws cli-Befehle sollten funktionieren:
aws s3 rm s3://<your_bucket_name> --exclude "*" --include "<your_regex>"
Wenn Sie Unterordner einschließen möchten, sollten Sie das Flag --recursive hinzufügen
oder mit Unix-Befehlen:
aws s3 ls s3://<your_bucket_name>/ | awk '{print $4}' | xargs -I% <your_os_shell> -c 'aws s3 rm s3:// <your_bucket_name> /% $1'
Erläuterung:
Wenn Sie versuchen, eine Datei mit Ihrer eigenen lokalen Hostkonsole zu löschen, können Sie versuchen, dieses Python-Skript auszuführen, vorausgesetzt, Sie haben Ihre Zugriffs-ID und Ihren geheimen Schlüssel bereits im System zugewiesen
import boto3
#my custom sesssion
aws_m=boto3.session.Session(profile_name="your-profile-name-on-local-host")
client=aws_m.client('s3')
#list bucket objects before deleting
response = client.list_objects(
Bucket='your-bucket-name'
)
for x in response.get("Contents", None):
print(x.get("Key",None));
#delete bucket objects
response = client.delete_object(
Bucket='your-bucket-name',
Key='mydocs.txt'
)
#list bucket objects after deleting
response = client.list_objects(
Bucket='your-bucket-name'
)
for x in response.get("Contents", None):
print(x.get("Key",None));
Das Folgende hat bei mir funktioniert (basierend auf einem Beispiel für ein Django-Modell, aber Sie können den Code der delete
Methode so ziemlich alleine verwenden).
import boto3
from boto3.session import Session
from django.conf import settings
class Video(models.Model):
title=models.CharField(max_length=500)
description=models.TextField(default="")
creation_date=models.DateTimeField(default=timezone.now)
videofile=models.FileField(upload_to='videos/', null=True, verbose_name="")
tags = TaggableManager()
actions = ['delete']
def __str__(self):
return self.title + ": " + str(self.videofile)
def delete(self, *args, **kwargs):
session = Session (settings.AWS_ACCESS_KEY_ID, settings.AWS_SECRET_ACCESS_KEY)
s3_resource = session.resource('s3')
s3_bucket = s3_resource.Bucket(settings.AWS_STORAGE_BUCKET_NAME)
file_path = "media/" + str(self.videofile)
response = s3_bucket.delete_objects(
Delete={
'Objects': [
{
'Key': file_path
}
]
})
super(Video, self).delete(*args, **kwargs)