Vega Lite / Kibana — Метка области не показывает значений

#elasticsearch #kibana #vega-lite #vega

#elasticsearch #kibana #vega-lite #vega

Вопрос:

У меня довольно простая проблема, но я совершенно новичок в Vega / Vega-Lite, и примеры из учебников не очень помогают мне решить мою проблему.

Когда я пытаюсь отобразить свои значения с плавающей запятой, кажется, работает только отметка: Point / Bar. Все остальное, что требует соединения между соседними точками, похоже, терпит неудачу, например, «Область» или «Линия».

Что я пропустил, чтобы связать мои значения с диаграммой областей? Агрегация? Слой? Неверно ли вычисляются значения временных меток?

 {
  "$schema": "https://vega.github.io/schema/vega-lite/v4.json",
  "data": {
    "url": {
      "%context%": true,
      "%timefield%": "@timestamp",
      "index": "default-*",
      "body": {"size": 10000, "_source": ["@timestamp", "numericData"]}
    },
    "format": {"property": "hits.hits"}
  },
  "transform": [
    {"calculate": "toDate(datum._source['@timestamp'])", "as": "time"}
  ],
  "vconcat": [
    {
      "width": 1200,
      "mark": {"type": "area", "line": true, "point": true},
      "encoding": {
        "x": {
          "field": "time",
          "scale": {"domain": {"selection": "brush"}},
          "type": "temporal",
          "axis": {"title": ""}
        },
        "y": {
          "field": "_source.numericData",
          "type": "quantitative",
          "scale": {"domain": [0, 10]}
        }
      }
    },
    {
      "width": 1200,
      "height": 60,
      "mark": {"type": "area", "line": true, "point": true},  // <-- only points are rendered :(
      "selection": {"brush": {"type": "interval", "encodings": ["x"]}},
      "encoding": {
        "x": {"field": "time", "type": "temporal"},
        "y": {
          "field": "_source.numericData",
          "type": "quantitative",
          "formatType": "String",
          "axis": {"tickCount": 3, "grid": false}
        }
      }
    }
  ]
}
 

Точки видны — значения есть, но область не отображается, потому что, я подозреваю, мне нужно сказать Vega Lite интерпретировать числовые значения с плавающей запятой для Y, которые будут интерпретироваться по всему временному полю.

Скриншот

Ответ №1:

Вы не поделились своими данными, поэтому я могу только догадываться, почему это происходит. Но одна из причин, по которой вы можете увидеть этот результат, заключается в том, что в ваших данных есть нулевые значения. Вот простой пример этого (открыть в редакторе):

 {
  "data": {
    "values": [
      {"x": 1, "y": 1},
      {"x": 2, "y": null},
      {"x": 3, "y": 2},
      {"x": 4, "y": null},
      {"x": 5, "y": 3},
      {"x": 6, "y": null}
    ]
  },
  "mark": {"type": "area", "point": true, "line": true},
  "encoding": {
    "x": {"field": "x", "type": "quantitative"},
    "y": {"field": "y", "type": "quantitative"}
  }
}
 

введите описание изображения здесь

В отличие от pont, линии и области определяются не через отдельные значения, а через смежные значения. Поскольку нет пар смежных ненулевых значений, нет места, где будет нарисована линия или область.

В этом случае вы можете удалить нулевые точки с помощью соответствующего преобразования фильтра (открыть в редакторе):

 {
  "data": {
    "values": [
      {"x": 1, "y": 1},
      {"x": 2, "y": null},
      {"x": 3, "y": 2},
      {"x": 4, "y": null},
      {"x": 5, "y": 3},
      {"x": 6, "y": null}
    ]
  },
  "transform": [{"filter": "isValid(datum.y)"}],
  "mark": {"type": "area", "point": true, "line": true},
  "encoding": {
    "x": {"field": "x", "type": "quantitative"},
    "y": {"field": "y", "type": "quantitative"}
  }
}
 

введите описание изображения здесь

Комментарии:

1. Вы, сэр, благословение! "filter": "datum._source['numericData'] != null" сделал это! Большое вам спасибо, что указали мне правильное направление. Я выясню, почему я получаю нулевые значения между ними при извлечении данных моего журнала из ES.