V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
ProximaCentauri
V2EX  ›  程序员

求助!请问这是什么数据结构,怎么把它转换为 json?

  •  
  •   ProximaCentauri · 2019-03-16 23:03:03 +08:00 · 2534 次点击
    这是一个创建于 2113 天前的主题,其中的信息可能已经有所发展或是发生改变。
    {
        "root1"
        {
            "item1"    "1"
            "item2"    "abc"
            
            "item3"
            {
                "cell"
                {
                    "cell1"
                    {
                        "cell1Name"    "99"
                    }
                    "cell2"
                    {
                        "cell2Name"    "cdb"
                    }    
                }
            }
            
            "item4"    "valueI"
        }

        "root2"
        {
            "item1"    "88"
            "item2"    "tg"
            
            "item3"
            {
                "cell"
                {
                    "cell1"
                    {
                        "cell1Name"    "99"
                    }
                    "cell2"
                    {
                        "cell2Name"    "ujh"
                    }
                    
                }
            }
            
            "item4"    "valueb"
        }
    }
    11 条回复    2019-03-18 14:55:23 +08:00
    ProximaCentauri
        1
    ProximaCentauri  
    OP
       2019-03-16 23:03:22 +08:00
    {
        "root1"
        {
            "item1"    "1"
            "item2"    "abc"
            
            "item3"
            {
                "cell"
                {
                    "cell1"
                    {
                        "cell1Name"    "99"
                    }
                    "cell2"
                    {
                        "cell2Name"    "cdb"
                    }    
                }
            }
            
            "item4"    "valueI"
        }

        "root2"
        {
            "item1"    "88"
            "item2"    "tg"
            
            "item3"
            {
                "cell"
                {
                    "cell1"
                    {
                        "cell1Name"    "99"
                    }
                    "cell2"
                    {
                        "cell2Name"    "ujh"
                    }
                    
                }
            }
            
            "item4"    "valueb"
        }
    }
    Cat73
        2
    Cat73  
       2019-03-16 23:13:57 +08:00 via iPad
    emmm 少了个冒号的 JSON ?似乎做几个正则替换也可以转成正常 JSON,想严谨的话可以自己写个状态机来解析
    ProximaCentauri
        3
    ProximaCentauri  
    OP
       2019-03-16 23:24:15 +08:00
    @Cat73 请问如果用状态机解析的话,可不可以给我指点一下大概的思路
    guiqiqi
        4
    guiqiqi  
       2019-03-17 00:47:59 +08:00 via iPhone   ❤️ 1
    @ProximaCentauri 把空格换一下成冒号,之后如果想按照树解析可以看看我之前的文章,有问题欢迎提出。

    https://init.blog/archives/1616
    zgl263885
        5
    zgl263885  
       2019-03-17 01:14:01 +08:00 via iPhone
    跟 json 比,不光缺少冒号,还有逗号和中括号。转换算法的话,我觉得需要个递归来替换或者添加缺少的符号。
    tinytin
        6
    tinytin  
       2019-03-17 01:20:52 +08:00 via iPhone
    Hjson ?
    ETiV
        7
    ETiV  
       2019-03-17 01:27:43 +08:00   ❤️ 1
    搜:「$\n(\s+{)」,换成:「\n$1 」
    搜:「" "」,换成:「": "」
    搜:「(["}])$\n(\s+["])」,换成:「$1,\n$2 」

    在 sublime 里试了一下这样的正则替换,能反算成 JSON
    ETiV
        8
    ETiV  
       2019-03-17 01:31:48 +08:00
    第一个是换成 「:\n$1 」,复制的时候漏了个小冒号
    第二个是搜双引号间的四个空格,帖子的显示的时候,代码被浏览器给省略显示了…
    neoblackcap
        9
    neoblackcap  
       2019-03-17 02:27:14 +08:00   ❤️ 1
    @ProximaCentauri 状态机就是传统写 parser 那一套,你该去找 flex & bison 那类编译器生成器
    不过我感觉你这个东西像是 php 输出的 hash
    ysc3839
        10
    ysc3839  
       2019-03-17 02:27:17 +08:00
    oaix
        11
    oaix  
       2019-03-18 14:55:23 +08:00   ❤️ 1
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1090 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 19:04 · PVG 03:04 · LAX 11:04 · JFK 14:04
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.