在函数循环中附加JSON

2024-06-25 23:24:05 发布

您现在位置:Python中文网/ 问答频道 /正文

我使用MQTT从传感器中检索数据,并且我使用它能够在传感器启动的时间工作。然后我试着把它写成一个JSON。
目前,我有一个问题,每次它附加新数据的JSON,但它也会添加相同的标题。你知道吗

我使用的代码是python和current脚本,在一个无限循环的函数中写入JSON。你知道吗

    def on_message(client, userdata, msg): 
           if sensone > 0.275 and sensone < 0.315 and c == 0:
                print("Timer Started")
                t0 = time.time()
                dt0 = datetime.datetime.now()
                dt0 = dt0.strftime('%Y-%m-%d %H:%M:%S')
                c += 1   
           if senstwo > 0.275 and senstwo < 0.315 and c == 1:
                t1 = time.time()
                dt1 = datetime.datetime.now()
                dt1 = dt1.strftime('%Y-%m-%d %H:%M:%S')
                with open('SensorTimes.json', 'a') as outfile:
                    datalog = {}
                    datalog['SensorTimes'] = []
                    datalog['SensorTimes'].append({
                        "Start Time":dt0, 
                        "End Time":dt1, 
                        "Total Time":round(t1-t0, 2)
                    })
                    json.dump(datalog, outfile, indent=4)
client = mqtt.Client()
client.on_connect = on_connect
client.on_message = on_message

client.connect("172.18.65.123", 1883)

client.loop_forever()

我已经删除了脚本中不相关的部分,我将其全部放在if语句中,因为如果它不在限制之间,我不希望记录数据。你知道吗

电流输出:

{
    "SensorTimes": [
        {
            "Start Time": "2019-03-28 09:03:10",
            "End Time": "2019-03-28 09:03:12",
            "Total Time": 2.22
        }
    ]
}{
    "SensorTimes": [
        {
            "Start Time": "2019-03-28 09:03:38",
            "End Time": "2019-03-28 09:03:41",
            "Total Time": 3.02
        }
    ]
}

预期输出:

    {
        "SensorTimes": [
            {
                "Start Time": "2019-03-28 09:03:10",
                "End Time": "2019-03-28 09:03:12",
                "Total Time": 2.22
            },
            {
                "Start Time": "2019-03-28 09:03:38",
                "End Time": "2019-03-28 09:03:41",
                "Total Time": 3.02
            }
        ]
    }

在此方面的任何帮助都将不胜感激。你知道吗


Tags: and数据clientjsondatetimetimeonstart
2条回答

实际上,您是用append标记("a")打开文件的,因此它将您在使用json.dump()时写入的内容附加到文件中

为了防止这种情况,首先用open('SensorTimes.json', 'r').read()读取文件以获取其内容。然后将其转换为json。然后将新内容附加到这个json中。并使用open('SensorTimes.json', 'w').write(newJson)json.dump(newJson, open('SensorTimes.json', 'w'))将其写入文件

也可以使用"r+"标记直接打开文件进行读写

在尝试了许多不同的组合后,我终于成功了!你知道吗

我将JSON append放入一个单独的函数中,该函数在if语句中被调用,然后返回到原始函数。你知道吗

datalog = {}
datalog['SensorTimes'] = []
def json_update(dt1, t1, dt0, t0):
    with open(r'SensorTimes.json', 'w') as outfile:
        datalog['SensorTimes'].append({
                    "Start Time":dt0, 
                    "End Time":dt1, 
                    "Total Time":round(t1-t0, 2)
                })   
        json.dump(datalog, outfile, indent=4)
    return

这将给出预期的输出,并将在不确定函数中一直工作。这会将新字典添加到JSON中,并且不会覆盖JSON的现有字典/内容。你知道吗

相关问题 更多 >