免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 16591 | 回复: 19
打印 上一主题 下一主题

[文本处理] 如何通过shell取得下面JSON里的数据 [复制链接]

论坛徽章:
0
跳转到指定楼层
[收藏(0)] [报告]
发表于 2017-04-14 08:26 |只看该作者 |正序浏览

JSON文件内容如下:
[
  {
    "target": "test",
    "datapoints": [
      [
        150662802.886176,
        1491871680
      ],
      [
        148571954.715462,
        1491871740
      ],
      [
        151503913.757496,
        1491871800
      ]
    ]
  }
]



如何通过shell取得里面的值分别写到一个数组里?
就是所有后面带小数点的乘8取出来放到一个数组里,不带小数点的乘1000放到另外一个数组里

论坛徽章:
0
19 [报告]
发表于 2019-01-16 20:42 |只看该作者
回复 16# jason680

您好,json文件内容如下
{
    "targets" : [
      "Yinhuahua",
      "GoldPigLoan",
      "RandomLoan",
      "FortuneWallet"
    ]
}



我需要在另外一个shell脚本里读取这个json文件的数组并保存为变量,给后续脚本使用。

请问如何编写脚本?

非常抱歉,shell新手,还请不吝赐教

论坛徽章:
0
18 [报告]
发表于 2017-04-25 08:42 |只看该作者
本帖最后由 icefishxmg 于 2017-04-25 09:59 编辑

回复 17# jason680
终于搞定了!谢谢兄弟!十分感谢!

论坛徽章:
0
17 [报告]
发表于 2017-04-24 08:25 |只看该作者
回复 17# jason680

我把笑脸转换过来,执行还是报错

论坛徽章:
0
16 [报告]
发表于 2017-04-24 08:09 |只看该作者
本帖最后由 icefishxmg 于 2017-04-24 08:24 编辑

回复 17# jason680

$ jq '.[] | {data: .datapoints}' a.json | awk -vlast=2 'BEGIN{printf("{\n%4s\"constr\": \"Chart\",\n%4s\"options\": {\"xAxis\":{\"type\":\"datetime\"},\"series\":[",x,x)}/"data":/{++d;b=c=1;sd=$1}/^ +[0-9.,]+$/{a[d,b%last,c]=$1;++c}/^ +[0-9.]+$/{++b;c=1}END{for(nd=1;nd<=d;++nd){s=s ndc "{" sd "[";ndc=", ";nbc="";for(nb=0;nb<last;++nb){k=(nb+b)%last;s=s nbc sprintf("[%d, %f]",a[nd,k,2]*1000,a[nd,k,1]*8);nbc=", "}s=s "], \"type\":\""((++cnt==1)?"":"area";)"spline\"}"}print s "]}\n}"}'

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
15 [报告]
发表于 2017-04-19 13:17 |只看该作者
本帖最后由 jason680 于 2017-04-24 11:00 编辑

回复 11# icefishxmg

4/24 11:00 禁用表情(笑臉)

$ jq '.[] | {data: .datapoints}' a.json | awk -vlast=2 'BEGIN{printf("{\n%4s\"constr\": \"Chart\",\n%4s\"options\": {\"xAxis\":{\"type\":\"datetime\"},\"series\":[",x,x)}/"data":/{++d;b=c=1;sd=$1}/^ +[0-9.,]+$/{a[d,b%last,c]=$1;++c}/^ +[0-9.]+$/{++b;c=1}END{for(nd=1;nd<=d;++nd){s=s ndc "{" sd "[";ndc=", ";nbc="";for(nb=0;nb<last;++nb){k=(nb+b)%last;s=s nbc sprintf("[%d, %f]",a[nd,k,2]*1000,a[nd,k,1]*8);nbc=", "}s=s "], \"type\":\""((++cnt==1)?"":"area")"spline\"}"}print s "]}\n}"}'
{
    "constr": "Chart",
    "options": {"xAxis":{"type":"datetime"},"series":[{"data":[[1491954480000, 816483298.020712], [1491954540000, 811037709.889904]], "type":"spline"}, {"data":[[1491959820000, 3050801490.174752], [1491959880000, 2995162978.060440]], "type":"areaspline"}]}
}

论坛徽章:
0
14 [报告]
发表于 2017-04-18 15:45 |只看该作者
回复 15# 本友会机友会摄友会

你这个是用什么写的?

论坛徽章:
0
13 [报告]
发表于 2017-04-18 15:09 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
12 [报告]
发表于 2017-04-17 14:58 |只看该作者
回复 12# jason680

我自己琢磨了半天没实现,还请大神帮下忙,谢谢!十分感谢!

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
11 [报告]
发表于 2017-04-17 14:37 |只看该作者
回复 11# icefishxmg

Would you modify it by yourself

论坛徽章:
0
10 [报告]
发表于 2017-04-17 13:39 |只看该作者
回复 10# jason680

兄弟,我两组数组最后的type内容不一样应该怎么改呢?一个要spline一个要areaspline
  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP