Python程序,如果不存在,则使用分区键和唯一键创建容器

Python程序,如果不存在,则使用分区键和唯一键创建容器,python,azure-cosmosdb,Python,Azure Cosmosdb,我想编写python脚本来创建容器,前提是它不存在分区键和唯一键 Steps for Creating Alert Container 1. Create Container With Container ID: alerts 2. Add Partition Key as /user_tenant 3. Add Unique Key as /alert_id 参考链接: 如果容器不存在,请建议创建容器的api。@Gaurav Mantri 下面是您建议的工作代码。 对于uniqueK

我想编写python脚本来创建容器,前提是它不存在分区键和唯一键

Steps for  Creating Alert Container
 1. Create Container With Container ID: alerts
 2. Add Partition Key as /user_tenant
 3. Add Unique Key as /alert_id
参考链接:

如果容器不存在,请建议创建容器的api。

@Gaurav Mantri 下面是您建议的工作代码。 对于uniqueKeys我们需要将其添加到uniqueKeyPolicy中,如下代码所示

import azure.cosmos.documents as documents
from azure.cosmos import cosmos_client, http_constants, errors
import os

url = os.environ['COSMOS_DB_END_POINT']
key = os.environ['COSMOS_DB_MASTER_KEY']
database_name = os.environ["COSMOS_DB_DATABASE_ID"]
client = cosmos_client.CosmosClient(url, {'masterKey': key})

container_definition = {'id': 'alerts_test',
                        'partitionKey':
                            {
                                'paths': ['/user_tenant'],
                                'kind': documents.PartitionKind.Hash
                            },
                        'uniqueKeyPolicy': {
                            'uniqueKeys':
                                [
                                    {'paths': ['/alert_id']}
                                ]
                        }
                        }

try:
    container = client.CreateContainer("dbs/" + database_name, container_definition, {'offerThroughput': 400})
    print("New Container Created:")
    print(container)
except errors.HTTPFailure as e:
    if e.status_code == http_constants.StatusCodes.CONFLICT:
        container = client.ReadContainer("dbs/" + database_name + "/colls/" + container_definition['id'])
        print(container)
    else:
        raise e

完美的我已删除我的答案,因为您提供了正确的解决方案。