跳至主要內容
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?

4563博客

全新的繁體中文 WordPress 網站
  • 首頁
  • 请教一下会 shell 处理 JSON 脚本的大佬
未分類
16 1 月 2020

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

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

資深大佬 : toyst 78

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

[{         "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)

  • 資深大佬 : noqwerty

    用 jq 应该可以?

  • 資深大佬 : mcfog

    jq 轻松搞定

  • 資深大佬 : wd

    用 py 或者 perl import json 比较容易

  • 資深大佬 : wamson

    Python 大法好

  • 資深大佬 : renmu

    [{”hash”:row[hash], ”name”:row[name]]} for row in data if data[num_leechs>10]] 这是 py 写法

  • 資深大佬 : ddsfeng

    因为不确定你说的 ‘就返回 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

    @ddsfeng 你好,再请教一下返回`name=xxx,hash=xxx`这种应该怎么写呢?

  • 資深大佬 : opticaline

    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

    最简单且可维护的之一是用 PowerShell

    Get-Content | ConvertFrom-Json | Write-Output | Where-Object num_leechs -gt 10 | Select-Object name, hash

  • 資深大佬 : Tink

    jq

  • 資深大佬 : ddsfeng

    @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

    @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

    jq
    自己多看看文档,你就能不求人了(或者可以帮助别人)

文章導覽

上一篇文章
下一篇文章

AD

其他操作

  • 登入
  • 訂閱網站內容的資訊提供
  • 訂閱留言的資訊提供
  • WordPress.org 台灣繁體中文

51la

4563博客

全新的繁體中文 WordPress 網站
返回頂端
本站採用 WordPress 建置 | 佈景主題採用 GretaThemes 所設計的 Memory
4563博客
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?
在這裡新增小工具