#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.