在Python中获得更深层次的JSON值

时间:2014-11-25 19:40:13

标签: python json api zendesk

我有一个Python脚本进行API调用以从Zendesk检索数据。 (使用Python 3.x)JSON对象具有如下结构:

{
  "id":               35436,
  "url":              "https://company.zendesk.com/api/v2/tickets/35436.json",
  "external_id":      "ahg35h3jh",
  "created_at":       "2009-07-20T22:55:29Z",
  "updated_at":       "2011-05-05T10:38:52Z",
  "type":             "incident",
  "subject":          "Help, my printer is on fire!",
  "raw_subject":      "{{dc.printer_on_fire}}",
  "description":      "The fire is very colorful.",
  "priority":         "high",
  "status":           "open",
  "recipient":        "support@company.com",
  "requester_id":     20978392,
  "submitter_id":     76872,
  "assignee_id":      235323,
  "organization_id":  509974,
  "group_id":         98738,
  "collaborator_ids": [35334, 234],
  "forum_topic_id":   72648221,
  "problem_id":       9873764,
  "has_incidents":    false,
  "due_at":           null,
  "tags":             ["enterprise", "other_tag"],
  "via": {
    "channel": "web"
  },
  "custom_fields": [
    {
      "id":    27642,
      "value": "745"
    },
    {
      "id":    27648,
      "value": "yes"
    }
  ],
  "satisfaction_rating": {
    "id": 1234,
    "score": "good",
    "comment": "Great support!"
  },
  "sharing_agreement_ids": [84432]
}

我遇到问题的地方特别在"custom_fields"部分。我在每张票中都有一个特定的自定义字段,我需要该值,而我只想要那个特定值。

为了免除Python代码的太多细节,我正在读取每个票据的下面的每个值,并在将该输出变量写入.csv之前将其添加到输出变量。这是破损发生的特殊地方:

output += str(ticket['custom_fields'][id:23825198]).replace(',', '')+',' 

所有替换废话都是为了确保因为它进入逗号分隔文件,所以删除值内的任何逗号。无论如何,这是我得到的错误:

    output += str(ticket['custom_fields'][id:int(23825198)]).replace(',', '')+','
TypeError: slice indices must be integers or None or have an __index__ method

正如您所看到的,我尝试了几种不同的变体来尝试解决问题,但尚未找到解决方法。我可以使用一些帮助!

...谢谢

1 个答案:

答案 0 :(得分:0)

您使用的是json.loads()吗?如果是这样,您可以获取密钥,并对密钥执行if语句。有关如何获取密钥及其各自值的示例如下所示。

import json

some_json = """{
"id":               35436,
"url":              "https://company.zendesk.com/api/v2/tickets/35436.json",
"external_id":      "ahg35h3jh",
"created_at":       "2009-07-20T22:55:29Z",
"updated_at":       "2011-05-05T10:38:52Z",
"type":             "incident",
"subject":          "Help, my printer is on fire!",
"raw_subject":      "{{dc.printer_on_fire}}",
"description":      "The fire is very colorful.",
"priority":         "high",
"status":           "open",
"recipient":        "support@company.com",
"requester_id":     20978392,
"submitter_id":     76872,
"assignee_id":      235323,
"organization_id":  509974,
"group_id":         98738,
"collaborator_ids": [35334, 234],
"forum_topic_id":   72648221,
"problem_id":       9873764,
"has_incidents":    false,
"due_at":           null,
"tags":             ["enterprise", "other_tag"],
"via": {
    "channel": "web"
},
"custom_fields": [
    {
    "sid":    27642,
    "value": "745"
    },
    {
    "id":    27648,
    "value": "yes"
    }
],
"satisfaction_rating": {
    "id": 1234,
    "score": "good",
    "comment": "Great support!"
},
"sharing_agreement_ids": [84432]
}"""

# load the json object
zenJSONObj = json.loads(some_json)

# Shows a list of all custom fields
print("All the custom field data")
print(zenJSONObj['custom_fields'])
print("----")
# Tells you all the keys in the custom_fields
print("How keys and the values")
for custom_field in zenJSONObj['custom_fields']:
    print("----")
    for key in custom_field.keys():
        print("key:",key," value: ",custom_field[key])

然后,您可以通过执行类似

的操作来修改JSON对象
print(zenJSONObj['custom_fields'][0])
zenJSONObj['custom_fields'][0]['value'] = 'something new'
print(zenJSONObj['custom_fields'][0])

然后使用以下内容重新编码:

newJSONObject = json.dumps(zenJSONObj, sort_keys=True, indent=4)

我希望这会有所帮助。