kibana 仪表制作历程(二)

图表生成后,上面显示的代码,想要把代码转换成对应的汉字,步骤如下:

1.在索引管理中,创建对应脚本,位置:

Managemen-->Index Patterns-->Scripted fields-->Add scripted field

我使用的脚本,功能上等同于sql的case when,但语法不同,下面是我用的代码:

if (doc['consumer_app_id'].contains("代码A"))
{return doc['consumer_app_id'].value+"-名称A"}
else if (doc['consumer_app_id'].contains("代码B"))
{return doc['consumer_app_id'].value+"-名称B"}
else if (doc['consumer_app_id'].contains("代码C"))
{return doc['consumer_app_id'].value+"-名称C"}
else {return doc['consumer_app_id'].value}

其中,consumer_app_id是我的数据里需要转换的的代码节点名称,相当于sql里的列名。

不能直接用等号=,contains为包含,相当于sql里的 in ;else if 可以多个,我这里返回的是拼接字符: “代码-名称”

之前有看其他人的博客,里面使用的是doc['consumer_app_id'].value.contains,他的是没问题,但我这里却报错,脚本测试时也看不出来,但在数据浏览界面上就会报(? of ? shards failed),说明转换的脚本有问题,又找了其他资料,去掉value后正常。

下面是我的截图(遮挡图片下面没有报错,即为正常)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值