問題タブ [elasticutils]
For questions regarding programming in ECMAScript (JavaScript/JS) and its various dialects/implementations (excluding ActionScript). Note JavaScript is NOT the same as Java! Please include all relevant tags on your question; e.g., [node.js], [jquery], [json], [reactjs], [angular], [ember.js], [vue.js], [typescript], [svelte], etc.
python - elasticutils によるフィルターを使用した ElasticSearch
filter
現在、ライブラリを介して既存の ElasticSearch インスタンスでa を使用しようとしていますelasticutils
。残念ながら、私はどこにも行きません。問題が基本的な間違いを犯したためなのか、それともライブラリに問題があるのか どうかはわかりません(AFAICTの可能性があります)。
文字列型のフィールド(「A」など)を含む特定のマッピングを持つインデックスを取得しました(明示的なアナライザーは指定されていません)。そのフィールドには常に文字列のリストが含まれています。
そのフィールドAに特定の文字列を含めることでドキュメントをフィルタリングしたいので、試しました:
しかし、それは空の結果セットを返します。も使用してみましf = eu.F(A__in="text")
たが、その結果、大きなエラー メッセージが表示されました。最も興味深い部分は[terms] filter does not support [A]
.
インデックスを別の方法で構成する必要があるかどうか疑問に思っています。おそらく、フィルターを使用できるようにファセットを作成する必要がありますか? しかし、私が読んだドキュメントには、これに関するヒントは見つかりませんでした。
使いたい理由は、、 、 でfilter
自由に組み合わせられるからです。また、これもブール値である可能性があることを説明するいくつかの仕様を見つけましたが、それらは通常、 、、およびを参照していますが、これは私にとって十分な柔軟性がないと思います。しかし、またはに設定できる s のフラグについて言及している仕様もいくつか見つけました。それに関する情報は大歓迎です。and
or
not
query
must
should
must_not
operator
query
and
or
だから、私の質問は次のとおりです。
- 構成の問題ですか?ファセットはこれと関係がありますか?
- ライブラリをスキップして、これがライブラリのバグかどうかをテストしたいのですが、たとえば、curl だけを使用してこのフィルタリング アクションを実行するにはどうすればよいですか? または他のライブラリ(おそらく
pyes
)? - 複数のクエリを柔軟に組み合わせる (
and
、or
、 、およびそれらのグループ化を使用する) ことは可能ですか (つまり、フィルターをまったく使用しません)?not
どうすればいいですか?(できれば、elasticutils
他のライブラリ構文、たとえばpyes
、または単純な CURL も同様に歓迎されます)。
django - Elasticutils で Multi_Field をクエリする
エラスティック サーチで、1 つの multi_field タイプを使用してインデックスに次のマッピングを定義しました。
Mozilla の ElasticUltis が気に入っていますが、multi_field フィールドを照会する方法が見つかりませんでした。
私は次のようなものを期待していたでしょう:
Elasticutils で multi_field フィールドをクエリする方法を知っている人はいますか?
django - Elasticsearch フィルター (数値フィールド) は何も返しません
型マッピング
すべてを照会:
戻り値:
しかし、次を使用してフィルタリングすると:
そのリターンは何もありません!
何が間違っているのかわかりません。Django と Elasticsearch の通信には、私は Elasticutils ( https://github.com/mozilla/elasticutils ) ですが、現在は Sense を使用してこれらのクエリを作成しています。
前もって感謝します
python - すべての結果を返すときに Elasticsearch が非常に遅い
〜113000のドキュメントのインデックスがあります。私はそれらすべてを取得しようとしていますが、スコアは気にしません。基本的に select * from index;
そして、私はelasticutilsを使用してPythonでこれを行っています(まだelasticsearch-dslに切り替える時間が見つかりません)
ランニング
約 0.003 秒で完了します。
ランニング
約15秒かかります。
ドキュメントについて私が理解していることから、両方とも実行を強制する必要があるため、時間に大きな違いがある理由がわかりません。
マッピングで、フィールドを分析しないようにマークしようとしましたが、効果はありませんでした。なぜこんなに桁違いの違いがあるのか 本当にわかりません。
python - Python Elasticutils http 認証または API キー?
こんにちは、現在djangoでelasticutilsを使用してインデックス付きドキュメントを検索していますが、クラスターには認証方法がないため、誰でもインターネットからESサーバーにアクセスできます.elasticutilsで認証方法のキーを設定する方法はありますか?キーを持つ唯一のサーバーが ES サーバーにクエリを実行できますか?
おそらく検索またはAmazonキーAPIの何か