kan*_*bla 2 python json append amazon-s3
我需要附加到 aws S3 上的 json 文件,python 代码正在 EC2 实例上运行。
在本地设置中,我可以轻松地执行此操作,如下所示:
import json
#example data
json_data = {"id": "123", "name": "XYZ", "transaction": [20.0, 30.0]}
# path
local_path = '/home/ubuntu/test.json'
with open(local_path, 'a', encoding='utf-8-sig') as file:
json.dump(json_data, file)
file.write('\n')
file.close()
Run Code Online (Sandbox Code Playgroud)
在 EC2 上,我可以按如下方式连接到 S3:
import boto
s3_open = boto.connect_s3(host='s3.eu-central-1.amazonaws.com')
Run Code Online (Sandbox Code Playgroud)
我定义了S3的路径:
s3_path = 's3://my-bucket/test.json'
Run Code Online (Sandbox Code Playgroud)
如何使用上述逻辑附加到该文件?
S3 没有追加操作,您可以做的就是下载文件,自行追加,然后将其作为同一对象的新版本上传。
沿着这些思路。
import json
import boto3
s3_path = '/some/s3/path'
bucket = 'somebucket'
local_data = {"id": "123", "name": "XYZ", "transaction": [20.0, 30.0]}
s3 = boto3.client('s3')
resp=s3.get_object(Bucket=bucket, Key=s3_path)
data=resp.get('Body')
json_data = json.loads(data)
json_data.append(local_data)
s3.put_object(Bucket=bucket, Key=s3_path, Body=json.dumps(json_data).encode())
Run Code Online (Sandbox Code Playgroud)