下面是字典和键值对的列表:
[{'name': 'test-project',
'properties': {'name': 'test-project',
'parent': {'id': '', 'type': 'folder'},
'projectId': 'test-project'},
'type': 'cloudresourcemanager.v1.project'},
{'metadata': {'dependsOn': ['test-project']},
'name': 'billing_test-project',
'properties': {'billingAccountName': 'billingAccountName',
'name': 'projects/test-project'},
'type': 'deploymentmanager.v2.virtual.projectBillingInfo'},
{'name': 'apis',
'properties': {'apis': ['compute.googleapis.com'],
'billing': 'billing_test-project',
'concurrent_api_activation': True,
'project': 'test-project'},
'type': 'apis.py'},
{'name': 'service-accounts',
'properties': {'project': 'test-project',
'service-accounts': ''},
'type': 'service-accounts.py'},
{'action': 'gcp-types/compute-v1:compute.projects.setUsageExportBucket',
'metadata': {'dependsOn': ['test-project',
'test-project-compute.googleapis.com']},
'name': 'set-export-bucket',
'properties': {'bucketName': 'gs://usage-exports',
'project': 'test-project',
'reportNamePrefix': 'usage_gce_'}}]}我需要将其转换为以下语法:
资源:\n-名称: test-project\n属性:\n名称: test-project\n父级:\n id:\n类型:文件夹\n
我想,也许下面这样的东西会在我的Google搜索之后起作用:
'\n'.join(d for d in resources)不幸的是,这给了我一个错误:"TypeError:序列项0:预期的str实例,dict“
如果能对此提供任何帮助,我们将不胜感激。
(顺便提一句,Google将配置内容作为字符串的唯一例子是用来创建VM:https://cloud.google.com/deployment-manager/docs/deployments#api;我注意到每个键值对的空格似乎都在增加,但我不完全确定这里是否需要这样的内容)。
编辑:抱歉,我想说我需要一个类似于下面的格式的键值对,作为一个字符串:
resource = "resources:\n- name: vm-created-by-cloud-config\n type: compute.v1.instance\n properties:\n zone: us-central1-a\n machineType: https://www.googleapis.com/compute/v1/projects/myproject/zones/us-central1-a/machineTypes/n1-standard-1\n disks:\n - deviceName: boot\n type: PERSISTENT\n boot: true\n autoDelete: true\n initializeParams:\n diskName: disk-created-by-cloud-config\n sourceImage: https://www.googleapis.com/compute/v1/projects/debian-cloud/global/images/debian-7-wheezy-v20151104\n networkInterfaces:\n - network: https://www.googleapis.com/compute/v1/projects/myproject/global/networks/default\n"所以,当印刷的时候,看起来是这样的:
resources:
- name: test-project
properties:
name: test-project
parent:
id:
type: folder
projectId: test-project
type: cloudresourcemanager.v1.project
- metadata:
dependsOn: test-project
name: billing_test-project
properties:
billingAccountName: billingAccountName
name: projects/test-project
type: deploymentmanager.v2.virtual.projectBillingInfo
- name: apis
properties:
apis: compute.googleapis.com
billing: billing_test-project
concurrent_api_activation: True
project: test-project
type: apis.py
- name: service-accounts
properties:
project: test-project
service-accounts:
type: service-accounts.py
- action: gcp-types/compute-v1:compute.projects.setUsageExportBucket
metadata:
dependsOn: test-project,test-project-compute.googleapis.com
name: set-export-bucket
properties:
bucketName: gs://usage-exports
project: test-project
reportNamePrefix: usage_gce_发布于 2020-05-18 16:39:08
尝试应用以下递归函数。这应该适用于您的特定用例:
resources = {'resources': [{'name': 'test-project',
'properties': {'name': 'test-project',
'parent': {'id': '', 'type': 'folder'},
'projectId': 'test-project'},
'type': 'cloudresourcemanager.v1.project'},
{'metadata': {'dependsOn': ['test-project']},
'name': 'billing_test-project',
'properties': {'billingAccountName': 'billingAccountName',
'name': 'projects/test-project'},
'type': 'deploymentmanager.v2.virtual.projectBillingInfo'},
{'name': 'apis',
'properties': {'apis': ['compute.googleapis.com'],
'billing': 'billing_test-project',
'concurrent_api_activation': True,
'project': 'test-project'},
'type': 'apis.py'},
{'name': 'service-accounts',
'properties': {'project': 'test-project',
'service-accounts': ''},
'type': 'service-accounts.py'},
{'action': 'gcp-types/compute-v1:compute.projects.setUsageExportBucket',
'metadata': {'dependsOn': ['test-project',
'test-project-compute.googleapis.com']},
'name': 'set-export-bucket',
'properties': {'bucketName': 'gs://usage-exports',
'project': 'test-project',
'reportNamePrefix': 'usage_gce_'}}]}
def unpack_dict(d, spaces=0):
try:
s = ' ' * spaces
spaces += 2
return ' '.join([f'\n{s}{k}: {unpack_dict(v, spaces)}' for k, v in d.items()])
except AttributeError:
if isinstance(d, list):
return ''.join([unpack_dict(item) for item in d])
else:
return d
result = unpack_dict(resources).strip()print(result)的输出
resources:
name: test-project
properties:
name: test-project
parent:
id:
type: folder
projectId: test-project
type: cloudresourcemanager.v1.project
metadata:
dependsOn: test-project
name: billing_test-project
properties:
billingAccountName: billingAccountName
name: projects/test-project
type: deploymentmanager.v2.virtual.projectBillingInfo
name: apis
properties:
apis: compute.googleapis.com
billing: billing_test-project
concurrent_api_activation: True
project: test-project
type: apis.py
name: service-accounts
properties:
project: test-project
service-accounts:
type: service-accounts.py
action: gcp-types/compute-v1:compute.projects.setUsageExportBucket
metadata:
dependsOn: test-projecttest-project-compute.googleapis.com
name: set-export-bucket
properties:
bucketName: gs://usage-exports
project: test-project
reportNamePrefix: usage_gce_请注意:
str类的format()函数。unpack_dict()函数,传递那个时态字典而不是原始的resources。https://stackoverflow.com/questions/61873581
复制相似问题