gpt4 book ai didi

python - Python 中的 JSON 导航 (PowerBI API)

转载 作者:太空宇宙 更新时间:2023-11-03 20:37:35 24 4
gpt4 key购买 nike

我正在尝试学习 python,并希望使用它与 PowerBI API 进行交互,特别是检查数据集的当前参数:

getParametersInGroup API

我已经创建了一个函数,可以成功返回我需要的数据,但我想过滤它,但它有点超出我的能力..

    def check_dataset_parameter(access_token, parameter_name = "FarmId"):
url = "https://api.powerbi.com/v1.0/myorg/groups/" + group_id + "/datasets/" + dataset_id + "/parameters"
headers = {
'content-type': "application/json",
'authorization': "Bearer " + access_token,
}
response = requests.request("GET", url, data=None, headers=headers)
response_full_json = response.json()
response_value_str = str(response.json()['value'])
parameter_list_clean = response_value_str.replace("'", '"').replace('[', '').replace(']', '').replace(' ', '')
actual_value_i_want = response.json()['value'][0]['currentValue']
current_value = actual_value_i_want ###Except I want the current value of the parameter specified in the function call
return current_value

此代码返回“179”,因为它是位置 0 处的 currentValue。我想要的是返回函数调用中指定的参数(FarmId 或 OrgId)的当前值。

parameter_list_clean 的输出是:

{"name":"FarmId","type":"Text","isRequired":True,"currentValue":"179"},{"name":"OrgId","type":"Number","isRequired":True,"currentValue":"-1"}

我这样做是为了尝试将字符串转换为字典,但它失败了,我还尝试了各种形式的 json.loads 和 json.dumps。

response_full_json 的原始输出如下所示:

{'@odata.context': 'http://wabi-australia-southeast-redirect.analysis.windows.net/v1.0/myorg/groups/<my_group>/$metadata#parameters', 'value': [{'name': 'FarmId', 'type': 'Text', 'isRequired': True, 'currentValue': '179'}, {'name': 'OrgId', 'type': 'Number', 'isRequired': True, 'currentValue': '-1'}]}

最佳答案

我找到了答案。问题是response.json()['value']返回的数据实际上是一个包含两个(或更多)字典的列表。我设法使用 next() 隔离所需的单个字典:

    def check_dataset_parameter(access_token, parameter_name="FarmId"):
url = "https://api.powerbi.com/v1.0/myorg/groups/" + group_id + "/datasets/" + dataset_id + "/parameters"
headers = {
'content-type': "application/json",
'authorization': "Bearer " + access_token,
}
response = requests.request("GET", url, data=None, headers=headers)
response_value = response.json()['value']
parameter_dict = next((item for item in response_value if item["name"] == parameter_name), None)
current_value = parameter_dict['currentValue']
return current_value

我发现这个问题非常有帮助: Python list of dictionaries search

关于python - Python 中的 JSON 导航 (PowerBI API),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57068379/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com