python - AWS Boto3(Python):如何将来自多个图像输入的多个响应保存到单个文件?
问题描述
以下代码用于 AWS Rekognition 图像标签检测。
问题 1)由于 AWS Recognition 一次只能运行一个图像,所以我使用 [List] 一次添加多个图像。但是,如果我想运行 100 个图像怎么办?这意味着我必须在 [List] 中手动写入 100 张图像的名称,这将花费很长时间。假设我有 100 张名为 image1、image2、image3、... image100 的图像,解决此问题的最佳方法是什么?
问题 2)下面的代码会将所有 3 个图像的响应保存到一个 JSON 文件中。如何将响应保存到单个文件中?
# List to record all the responses
responselist=[]
list=['picture1.jpg','picture2.jpg','picture 3.jpg']
for image in list :
response = client.detect_labels(
Image={
'S3Object': {
'Bucket': 'test1',
'Name': image
}})
responselist.append(response)
print(response)
# JASON file Save
json_file = json.dumps(response)
Path('rekognition_test.json').write_text(json_file)
解决方案
发布的代码没有按照您的想法执行。具体来说,它不会保存三个图像的结果。只有最后一个response
被保存。
这是因为您正在创建一个responselist
根本不使用的。也不要将您的列表称为 a list
,因为它是 python 的实际列表数据结构。
但是,如果您想分别为每个图像编写结果,您可以尝试以下操作:
my_list=['picture1.jpg','picture2.jpg','picture 3.jpg']
for image in my_list:
response = client.detect_labels(
Image={
'S3Object': {
'Bucket': 'test1',
'Name': image
}})
json_file = json.dumps(response)
Path(f"{image}.json").write_text(json_file)
推荐阅读
- python - 你如何让棋盘功能在 spyder 3.7 上工作?
- unity3d - 用于 Unity 的 xUnit 测试
- html - 以透明 png 精灵为背景图像的列表单击故障
- javascript - 如何在 Vue.js 中在两个不同的条件下绑定两个类?
- python - 使用 Flask Jinja2 模板将 JSON 数据发布到基于日期的表中
- go - go - 如何使用证书存储中的证书并在 gin 框架中运行 TLS?
- visual-studio-code - 如何停止 VSCode 选择错误的语法错误
- c# - 使用 Postman 将文件附加到 API 调用时遇到问题
- reactjs - 在 Redux 商店中包装 React navigator native
- javascript - 循环显示对象值十次