Elasticsearch学习之的delimited_payloads使用

想要为每个token添加负载信息,例如标注词性

  • elasticsearch中Token Filter:delimited_payloads
  • 注意事项:在设置tokenizer时必须不能把delimited_payloads中的分界符去掉
  • 实现:
PUT /20181105
{
  "settings": {
    "analysis": {
      "filter": {
        "payloads":{
          "type":"delimited_payload",
          "encoding":"int",
          "delimiter":"|"
        }
      },
      "analyzer": {
        "payloads":{
          "tokenizer":"whitespace",
          "filter":["payloads"],
          "char_filter":[]
          
        }
      }
    }
  },
  "mappings": {
    "doc":{
      "properties": {
        "text":{
          "type": "text",
          "analyzer": "payloads"
        }
      }
    }
  }
}
  • 测试:
GET  20181105/_analyze 
{
  "analyzer": "payloads",
  "text": "the|1  Quick|2 fox|3"
  
}
  • 结果:
"tokenfilters": [
      {
        "name": "payloads",
        "tokens": [
          {
            "token": "the",
            "start_offset": 0,
            "end_offset": 5,
            "type": "word",
            "position": 0,
            "bytes": "[74 68 65]",
            "payload": "[0 0 0 1]",
            "positionLength": 1,
            "termFrequency": 1
          },
          {
            "token": "Quick",
            "start_offset": 6,
            "end_offset": 13,
            "type": "word",
            "position": 1,
            "bytes": "[51 75 69 63 6b]",
            "payload": "[0 0 0 2]",
            "positionLength": 1,
            "termFrequency": 1
          },
          {
            "token": "fox",
            "start_offset": 14,
            "end_offset": 19,
            "type": "word",
            "position": 2,
            "bytes": "[66 6f 78]",
            "payload": "[0 0 0 3]",
            "positionLength": 1,
            "termFrequency": 1
          }
        ]
      }
    ]
  }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值