图表生成后,上面显示的代码,想要把代码转换成对应的汉字,步骤如下:
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后正常。
下面是我的截图(遮挡图片下面没有报错,即为正常)