/emoji-search

:smile: Emoji synonyms to build your own emoji-capable search engine (elasticsearch, solr)

Primary LanguageJavaMIT LicenseMIT

Emoji synonyms dictionary and custom tokenizer plugin for Elasticsearch

Add support for emoji in any Lucene compatible search engine!

What is this

This repository host information about Elasticsearch and emoji search:

  • synonym files in Solr / Lucene format for emoji search in all languages supported by Unicode CLDR;
  • emoticon suggestions for improved meaning extraction;
  • full elasticsearch analyzer configuration to copy and paste;
  • an experimental tokenizer plugin for Elasticsearch (help needed ⚠️).

Emoji data are based on the latest CLDR data set (Currently version 30.0.2 stable).

👩‍🚒 => 👩‍🚒, firefighter, firetruck, woman
👩‍✈ => 👩‍✈, pilot, plane, woman
🥓 => 🥓, bacon, meat, food
🥔 => 🥔, potato, vegetable, food
😅 => 😅, cold, face, open, smile, sweat
😆 => 😆, face, laugh, mouth, open, satisfied, smile
🚎 => 🚎, bus, tram, trolley
🇫🇷 => 🇫🇷, france
🇬🇧 => 🇬🇧, united kingdom

Learn more about this in our blog post describing how to search with emoji in Elasticsearch (2016).

Emoji analyzer for Elasticsearch (with the analysis-emoji plugin)

Go to the dedicated plugin documentation.

Emoji analyzer for Elasticsearch (without the plugin, not perfect)

Get the files in ./config/analysis/

Download the emoji and emoticon file you want from this repository and store them in PATH_ES/config/analysis.

config
├── analysis
│   ├── cldr-emoji-annotation-synonyms-en.txt
│   └── emoticons.txt
├── elasticsearch.yml
...

Create the analyzer

We call it english_with_emoji here because we use the english synonyms:

PUT /en-emoji
{
  "settings": {
    "analysis": {
      "char_filter": {
        "zwj_char_filter": {
          "type": "mapping",
          "mappings": [ 
            "\\u200D=>"
          ]
        },
        "emoticons_char_filter": {
          "type": "mapping",
          "mappings_path": "analysis/emoticons.txt"
        }
      },
      "filter": {
        "english_emoji": {
          "type": "synonym",
          "synonyms_path": "analysis/cldr-emoji-annotation-synonyms-en.txt" 
        },
        "punctuation_and_modifiers_filter": {
          "type": "pattern_replace",
          "pattern": "\\p{Punct}|\\uFE0E|\\uFE0F|\\uD83C\\uDFFB|\\uD83C\\uDFFC|\\uD83C\\uDFFD|\\uD83C\\uDFFE|\\uD83C\\uDFFF",
          "replace": ""
        },
        "remove_empty_filter": {
          "type": "length",
          "min": 1
        }
      },
      "analyzer": {
        "english_with_emoji": {
          "char_filter": ["zwj_char_filter", "emoticons_char_filter"],
          "tokenizer": "whitespace",
          "filter": [
            "lowercase",
            "punctuation_and_modifiers_filter",
            "remove_empty_filter",
            "english_emoji"
          ]
        }
      }
    }
  }
}

Try it!

GET /en-emoji/_analyze?analyzer=english_with_emoji
{
  "text": "I love 🍩"
}
# Result: i, love, 🍩, dessert, donut, sweet

GET /en-emoji/_analyze?analyzer=english_with_emoji
{
  "text": "You are ]:)"
}
# Result: you, are, 😈, face, fairy, fantasy, horns, smile, tale

GET /en-emoji/_analyze?analyzer=english_with_emoji
{
  "text": "Where is 🇫🇮?"
}
# Result: where, is, 🇫🇮, finland

How to contribute

Build from CLDR SVN

You will need:

  • php cli
  • svn

Edit the tag in tools/build-beta.php and run php tools/build-beta.php.

Update emoticons

Run php tools/build-emoticon.php.

Licenses

Emoji data courtesy of CLDR. See unicode-license.txt for details. Some modifications are done on the data, see here. Emoticon data based on https://github.com/wooorm/emoticon/ (MIT).

This repository in distributed under MIT License. Feel free to use and contribute as you please!