我想问一下是否有一个库可以拆分JSON字符串的“columns”和“data”。
目标:
我需要减少在我们开发的遥测系统中传输的数据量。
在引擎盖下,交换字符串化的json数据。如果我能够将“列”和“数据”分成不同的部分,我只会交换一次“列”,然后“数据”将占用更少的带宽:
orig_data = {"hello": 1, "how_are_you": "good"}
template = "{\"hello\": %d, \"how_are_you\": \"%s\"}"
data = (1, "good")
reconstructed_data = json.loads(template % data)
template
只会进行一次交换,然后data
将更有效地发送。
更有效的例子将在数字输入/输出交换中显示:
orig_data = {"heater_1_started": True, "heater_2_started": False, ..., "heater_76_started": False, "motor_1_running": False, ...}
会变成
data = [0x0345]
那么,是否有任何库可以获取JSON数据并从该信息生成template
?
最后,我想要一个自适应协议:
protocol_signature = crc32(template)
if protocol_signature not in synchronized_protocol_signatures:
send({'protocol': [protocol_signature, template]})
send([protocol_signature, data])
答案 0 :(得分:1)
如果字段始终以相同的顺序发送,则可以使用namedtuple。使用列名创建namedtuple
,然后只发送数据值并实例化namedtuple
类的副本。
from collections import namedtuple
import json
# Initial column names (send only once)
column_names = ['x', 'y', 'z']
MyData = namedtuple('MyData', column_names)
json_string_from_server = '[True, 1, "good"]'
json_data = json.loads(json_string_from_server)
data = MyData(*json_data)
print data.x, data.y, data.z
# True 1 "good"
就压缩发送的数据而言,它取决于您发送的数据类型。如果它主要是任意长度的字符串和整数,那么字符串化的json可能已经被压缩了。
如果您要将大部分开/关布尔标志压缩为单个位,则可以使用bitarray之类的库。
>>> from bitarray import bitarray
>>> a = bitarray() # create empty bitarray
>>> a.append(True)
>>> a.extend([False, True, True])
>>> a
bitarray('1011')