我正在尝试使用yaml文件来存储字典键,这样我就可以解析各种json有效负载。
我将以下yaml文件加载到名为‘cfg’的变量中:
my_table: metadata
当我运行时:
for i in json['resources']:
print(i[cfg['my_table']])
我可以很好地看到我的json的“metadata”键中的所有值。
但是,我希望看到存在于‘’下的资源‘metadata’资源键的所有值。因此,当我将yaml文件更改为:
my_table: metadata, guid
它不起作用。我也尝试过这些变体:
my_table: ['metadata', 'guid'] #tried ''.join("['{0}']".format(a) for a in cfg['my_table']) which gives me what I want, but when I shove this inside i[], I get a key error
my_table: ['metadata']['guid'] #yaml file doesn't parse properly
有什么想法吗?
发布于 2018-08-10 23:57:47
因此,您希望将字典键存储在yaml文件中?
只管去做
# keys.yaml
my_table: [metadata, guid]
然后在您的python文件中
keys = yaml.safe_load('keys.yaml')['my_table']
for obj in json['resources']: # don't call it json, that's a package name
print(obj[keys[0]][keys[1]])
对于可变数量的键(不只是两个),如下所示:
def recursive_getitem(obj, keys):
if len(keys) == 0:
return obj
return recursive_getitem(obj[keys[0]], keys[1:])
然后做
for obj in json['resources']:
print(recursive_getitem(obj, keys))
要回答注释中的第二个问题,您需要使用嵌套列表
# keys.yaml
my_table:
- [metadata, guid]
- [entity, name]
。
# py file
keys = yaml.safe_load('keys.yaml')['my_table']
for obj in json['resources']: # don't call it json, that's a package name
print(obj[keys[0][0]][keys[0][1]])
print(obj[keys[1][0]][keys[1][1]])
https://stackoverflow.com/questions/51789905
复制相似问题