异常:TypeError(字符串索引必须是整数)
Exception: TypeError(string indices must be integers)
我编写了以下 python 函数(完整代码的一个片段)以在 AWS Lambda 中运行。它的目的是从 S3 存储桶中获取 GeoJSON 并相应地解析它。
解析后,它被放回JSON格式(data
),然后应使用
插入到指定的数据库中
bulk_item['uuid'] = str(uuid.uuid4())
bulk_item['name'] = feature_name
bulk_item['type'] = feature_type
bulk_item['info'] = obj
bulk_item['created'] = epoch_time
bulk_item['scope'] = 2
data = json.dumps(bulk_item)
print(data)
self.database.upsert_record(self.organisation, json_doc=data)
except Exception as e:
print(f'Exception: {e.__class__.__name__}({e})')
与上述内容相关的db_access文件是另一个python脚本。函数upsert_record
如下:
def upsert_record(self, organisation,
json_doc={}):
在我尝试将其更新插入数据库之前,我的代码运行良好。一旦到达此行,它就会抛出错误
Traceback (most recent call last):
File "/var/task/s3_asset_handler.py", line 187, in process_incoming_file
self.database.upsert_record(self.organisation, json_doc=data)
File "/opt/python/database_access.py", line 1218, in upsert_record
new_uuid = json_doc['uuid']
TypeError: string indices must be integers
我好像完全想不通这个问题
您正在尝试从 JSON 对象中获取元素,但传递的是字符串。
data = json.dumps(bulk_item)
创建表示对象的字符串。
尝试单独使用 bulk_item
。
我编写了以下 python 函数(完整代码的一个片段)以在 AWS Lambda 中运行。它的目的是从 S3 存储桶中获取 GeoJSON 并相应地解析它。
解析后,它被放回JSON格式(data
),然后应使用
bulk_item['uuid'] = str(uuid.uuid4())
bulk_item['name'] = feature_name
bulk_item['type'] = feature_type
bulk_item['info'] = obj
bulk_item['created'] = epoch_time
bulk_item['scope'] = 2
data = json.dumps(bulk_item)
print(data)
self.database.upsert_record(self.organisation, json_doc=data)
except Exception as e:
print(f'Exception: {e.__class__.__name__}({e})')
与上述内容相关的db_access文件是另一个python脚本。函数upsert_record
如下:
def upsert_record(self, organisation,
json_doc={}):
在我尝试将其更新插入数据库之前,我的代码运行良好。一旦到达此行,它就会抛出错误
Traceback (most recent call last):
File "/var/task/s3_asset_handler.py", line 187, in process_incoming_file
self.database.upsert_record(self.organisation, json_doc=data)
File "/opt/python/database_access.py", line 1218, in upsert_record
new_uuid = json_doc['uuid']
TypeError: string indices must be integers
我好像完全想不通这个问题
您正在尝试从 JSON 对象中获取元素,但传递的是字符串。
data = json.dumps(bulk_item)
创建表示对象的字符串。
尝试单独使用 bulk_item
。