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

2019-12-13 09:14:07 +08:00
 toyst

逻辑是这样的,我想判断每段 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
    }
]

7699 次点击
所在节点    Z shell
13 条回复
noqwerty
2019-12-13 09:14:58 +08:00
用 jq 应该可以?
mcfog
2019-12-13 09:17:54 +08:00
jq 轻松搞定
wd
2019-12-13 09:19:40 +08:00
用 py 或者 perl import json 比较容易
wamson
2019-12-13 09:21:24 +08:00
Python 大法好
renmu
2019-12-13 09:26:40 +08:00
[{”hash”:row[hash], ”name”:row[name]]} for row in data if data[num_leechs>10]] 这是 py 写法
ddsfeng
2019-12-13 09:41:56 +08:00
因为不确定你说的 '就返回 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
2019-12-13 09:56:27 +08:00
@ddsfeng 你好,再请教一下返回`name=xxx,hash=xxx`这种应该怎么写呢?
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
2019-12-13 10:42:57 +08:00
最简单且可维护的之一是用 PowerShell

Get-Content | ConvertFrom-Json | Write-Output | Where-Object num_leechs -gt 10 | Select-Object name, hash
Tink
2019-12-13 11:15:40 +08:00
jq
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
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
2019-12-13 12:42:44 +08:00
jq
自己多看看文档,你就能不求人了(或者可以帮助别人)

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/628583

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX