V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
toyst
V2EX  ›  Z shell

请教一下会 shell 处理 JSON 脚本的大佬

  •  
  •   toyst · 2019-12-13 09:14:07 +08:00 · 7415 次点击
    这是一个创建于 1567 天前的主题,其中的信息可能已经有所发展或是发生改变。

    逻辑是这样的,我想判断每段 num_leechs 的值,如果大于 10,就返回 namehash 的值,代码如下:

    [{
            "added_on": 1576120104,
            "hash": "2fcb75646c688975daa840dfe466d21bc64118de",
            "name": "Ad.Astra.2019",
            "num_leechs": 545
        }, 
    {
            "added_on": 1576120104,
            "hash": "5c04a056d6821792db902b22aesdf23r2cd23rd23",
            "name": "ABC",
            "num_leechs": 32
        },
    {
            "added_on": 1576120104,
            "hash": "dfgsdfg34tv34tg34g34g6547h547h4567g567h45",
            "name": "eGE",
            "num_leechs": 2
        }
    ]
    
    
    13 条回复    2019-12-13 12:42:44 +08:00
    noqwerty
        1
    noqwerty  
       2019-12-13 09:14:58 +08:00 via Android
    用 jq 应该可以?
    mcfog
        2
    mcfog  
       2019-12-13 09:17:54 +08:00 via Android
    jq 轻松搞定
    wd
        3
    wd  
       2019-12-13 09:19:40 +08:00 via iPhone
    用 py 或者 perl import json 比较容易
    wamson
        4
    wamson  
       2019-12-13 09:21:24 +08:00 via iPhone
    Python 大法好
    renmu
        5
    renmu  
       2019-12-13 09:26:40 +08:00 via Android
    [{”hash”:row[hash], ”name”:row[name]]} for row in data if data[num_leechs>10]] 这是 py 写法
    ddsfeng
        6
    ddsfeng  
       2019-12-13 09:41:56 +08:00   ❤️ 1
    因为不确定你说的 '就返回 name 和 hash 的值', 是哪种格式的, 所以弄了两个, 自行选择..


    jq --> stedolan.github.io/jq/manual/

    1.json 为你帖的内容

    ```
    $ cat 1.json | jq '[.[] | select(.num_leechs > 10) | {name,hash}]'
    [
    {
    "name": "Ad.Astra.2019",
    "hash": "2fcb75646c688975daa840dfe466d21bc64118de"
    },
    {
    "name": "ABC",
    "hash": "5c04a056d6821792db902b22aesdf23r2cd23rd23"
    }
    ]
    ```


    ```
    $ cat 1.json | jq '[.[] | select(.num_leechs > 10) | [.name,.hash]]'
    [
    [
    "Ad.Astra.2019",
    "2fcb75646c688975daa840dfe466d21bc64118de"
    ],
    [
    "ABC",
    "5c04a056d6821792db902b22aesdf23r2cd23rd23"
    ]
    ]
    ```
    toyst
        7
    toyst  
    OP
       2019-12-13 09:56:27 +08:00
    @ddsfeng 你好,再请教一下返回`name=xxx,hash=xxx`这种应该怎么写呢?
    opticaline
        8
    opticaline  
       2019-12-13 10:35:39 +08:00
    cat temp | grep num_leechs -B 2 | awk -v RS="--" '{if($6 > 10){print $4,$2}}' | awk -F '[", ]' '{print "name="$2",hash="$6}'

    name=Ad.Astra.2019,hash=2fcb75646c688975daa840dfe466d21bc64118de
    name=ABC,hash=5c04a056d6821792db902b22aesdf23r2cd23rd23
    geelaw
        9
    geelaw  
       2019-12-13 10:42:57 +08:00 via iPhone
    最简单且可维护的之一是用 PowerShell

    Get-Content | ConvertFrom-Json | Write-Output | Where-Object num_leechs -gt 10 | Select-Object name, hash
    Tink
        10
    Tink  
       2019-12-13 11:15:40 +08:00 via iPhone
    jq
    ddsfeng
        11
    ddsfeng  
       2019-12-13 12:37:56 +08:00
    @toyst 你能一次性说完吗? 把你最终想要的结果, 完整的发出来.

    你现在这个, 依然说的是单个的, 你的结果里面有多个, 是返回数组吗?

    多个的时候这样吗???

    $ cat 1.json | jq '[.[] | select(.num_leechs > 10) | @text "name=\(.name),hash=\(.hash)"]'
    [
    "name=Ad.Astra.2019,hash=2fcb75646c688975daa840dfe466d21bc64118de",
    "name=ABC,hash=5c04a056d6821792db902b22aesdf23r2cd23rd23"
    ]
    ddsfeng
        12
    ddsfeng  
       2019-12-13 12:38:36 +08:00
    @toyst 还是说是这样????

    $ cat 1.json | jq '.[] | select(.num_leechs > 10) | @text "name=\(.name),hash=\(.hash)"'
    "name=Ad.Astra.2019,hash=2fcb75646c688975daa840dfe466d21bc64118de"
    "name=ABC,hash=5c04a056d6821792db902b22aesdf23r2cd23rd23"
    ETiV
        13
    ETiV  
       2019-12-13 12:42:44 +08:00 via iPhone
    jq
    自己多看看文档,你就能不求人了(或者可以帮助别人)
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1406 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 34ms · UTC 17:35 · PVG 01:35 · LAX 10:35 · JFK 13:35
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.