JQ:如何将被识别为字符串的值相乘?

4 bash json multiplication string-substitution jq

我正在尝试从交换网络套接字获取一些贸易信息。在我从套接字获取的 JSON 中,值 .p 和 .q 都用双引号括起来。

当我尝试将两个值相乘时,它表示我正在尝试将两个字符串相乘。因此,我通过 tonumber 过滤器传递这些字符串,并且错误消息发生了一些变化,但无法让它真正工作。

JSON:

{"e":"aggTrade","E":1562109562958,"s":"BTCUSDT","a":134343336,"p":"10796.60000000","q":"0.00139000","f":147532295,"l":147532295,"T":1562109562951,"m":false,"M":true}
Run Code Online (Sandbox Code Playgroud)

下面的命令后面是它们的输出:

... | jq  '"\(.p*.q)"'
    jq: error (at <stdin>:1): string ("10796.6000...) and string ("0.00139000") cannot be multiplied
Run Code Online (Sandbox Code Playgroud)

然后:

... | jq  '"\(.p|tonumber*.q|tonumber)"'
jq: error (at <stdin>:1): Cannot index string with string "q"
Run Code Online (Sandbox Code Playgroud)
... | jq  '"\("\(.p|tonumber)"*"\(.q|tonumber)")"'
jq: error (at <stdin>:1): string ("10796.6") and string ("0.00139") cannot be multiplied
Run Code Online (Sandbox Code Playgroud)

我得到的最接近的是下面的代码,但它输出了很多页结果,而我只期望一个结果......

... | jq  '.q as $qtty | "\(.p|tonumber*$qtty|tonumber)"'

Run Code Online (Sandbox Code Playgroud)

或者:

... | jq  '.q as $qtty | "\(.p|tonumber*"\($qtty|tonumber)")"'
Run Code Online (Sandbox Code Playgroud)

它输出的数字太多了!

即使使用 -r 选项,它也不起作用。我希望只出现乘法的原始结果,如下所示:

15.0072740
Run Code Online (Sandbox Code Playgroud)

Suf*_*ori 5

把事情简单化,

jq -r '(.p | tonumber)*(.q | tonumber)'
Run Code Online (Sandbox Code Playgroud)