简体   繁体   English

如何从 Json_response 中提取数据以用于 python

[英]How do I extract data from Json_response to be used in python

I am trying to integrate two APIs我正在尝试集成两个 API

  1. from metering platform that should send notifications via sms.从应该通过短信发送通知的计量平台。
  2. API is an sms platform to deliver the messages. API 是一个发送消息的短信平台。

Python Code; Python代码;

import africastalking
import requests
import json

# Initialize SDK
username = "sandbox" # use 'sandbox' for development in the test environment
# use your sandbox app API key for development in the test environment
api_key = "auth_key"
africastalking.initialize(username, api_key)


# Initialize a service e.g. SMS
sms = africastalking.SMS

url = "https://nay-bokani.sparkmeter.cloud/api/v0/sms/outgoing"

payload = json.dumps({
  "mark_delivered": False
})
headers = {
  'Content-Type': 'application/json',
  'Authentication-Token': 'auth_key'
}

response = requests.request("GET", url, headers=headers, data=payload)

# print()
json_response = response.json()

if json_response['status'] == 'success':
  if json_response["messages"][0]["timestamp"] == max("timestamp"):
    for s in range(len(json_response['messages'])):
      response = sms.send(json_response['messages']['text'], [json_response['messages']['phone_number']])
    print(response)

print(response.text)

json response json 响应

{
  "error": null,
  "messages": [ 
    {
      "id": "46186176-ba91-4072-a93e-0fc089dea750",
      "phone_number": "+2348000000000",
      "text": "You've just been credited with N10.00 worth of energy",
      "timestamp": "2021-06-09T10:14:10.795818"
    },
    {
      "id": "6709099c-22c8-4df5-88e1-24284d8ff61f",
      "phone_number": "+2348111111111",
      "text": "You've just been credited with N500.00 worth of energy",
      "timestamp": "2021-06-09T10:32:11.885605"
    }
  ],
  "status": "success"
}

I need to be able to extract the phone number and text and use it to send an auto sms using the sms API.我需要能够提取电话号码和文本,并使用它使用短信 API 发送自动短信。 I tried to use parse using the recent timestamp, but that will be a problem when multiple json data is returned.我尝试使用最近的时间戳进行解析,但是当返回多个 json 数据时,这将是一个问题。

import json

#cannot use the real sms.send function so define a dummy one
def dummy_sms_send(txt, phone):
    print(txt, phone)

json_response = """
{
  "error": null,
  "messages": [ 
    {
      "id": "46186176-ba91-4072-a93e-0fc089dea750",
      "phone_number": "+2348000000000",
      "text": "You've just been credited with N10.00 worth of energy",
      "timestamp": "2021-06-09T10:14:10.795818"
    },
    {
      "id": "6709099c-22c8-4df5-88e1-24284d8ff61f",
      "phone_number": "+2348111111111",
      "text": "You've just been credited with N500.00 worth of energy",
      "timestamp": "2021-06-09T10:32:11.885605"
    }
  ],
  "status": "success"
}
"""

decoded_response = json.loads(json_response)
if decoded_response["status"] == "success":
    for msg in decoded_response["messages"]:
        dummy_sms_send(msg["text"], msg["phone_number"])

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM