将字符串转换为 json,其中一些值包含在方括号中

Convert string to json where some values are wrapped in square brackets

string 转换为 dict 的最有效方法 (python 3) 是什么,其中一些键和值可能会或可能不会被引用,而一些值可能包含用方括号 ([]) 包裹的子对象,而不是大括号。

值中也可能包含冒号 (:)

示例:

string = "[key:value, key2:[key2a:val2:a, key2b:[foo:"bar"]]]"

结果必须是有效的 dict,例如:

{"key":"value", "key2":{"key2a":"val2:a", "key2b":{"foo":"bar"}}}

您可以使用递归生成器函数:

import re
string = "[key:value, key2:[key2a:val2:a, key2b:[foo:'bar']]]"
d = [i if not i.startswith("'") else i[1:-1] for i in re.findall("[\[\]]|:|'.*?'|\w+|,", string)[1:-1]]
def to_dict(d):
   while (n:=next(d, None)) not in {None, ']'}:
      _ = next(d)
      if (v:=next(d)) == '[':
         v = dict(to_dict(d))
      else:
         c = [v]
         while (j:=next(d)) not in {',', ']'}:
            c.append(j)
         if j == ']':
            d = iter([*d, j])
         v = ''.join(c)
      yield (n, v)

print(dict(to_dict(iter(d))))

输出:

{'key': 'value', 'key2': {'key2a': 'val2:a', 'key2b': {'foo': 'bar'}}}

编辑:没有赋值表达式的解决方案(:= 海象运算符):

def to_dict(d):
   n = next(d, None)
   while n not in {None, ']'}:
      _, v = next(d), next(d)
      if v == '[':
         v = dict(to_dict(d))
      else:
         c, j = [v], next(d)
         while j not in {',', ']'}:
            c.append(j)
            j = next(d)
         if j == ']':
            d = iter([*d, j])
         v = ''.join(c)
      yield (n, v)
      n = next(d, None)


print(dict(to_dict(iter(d))))