File: helpers.asciidoc

package info (click to toggle)
python-elasticsearch 8.17.2-2
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 20,124 kB
  • sloc: python: 69,424; makefile: 150; javascript: 75
file content (90 lines) | stat: -rw-r--r-- 2,428 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
[[client-helpers]]
== Client helpers

You can find here a collection of simple helper functions that abstract some 
specifics of the raw API. For detailed examples, refer to 
https://elasticsearch-py.readthedocs.io/en/stable/helpers.html[this page].


[discrete]
[[bulk-helpers]]
=== Bulk helpers 

There are several helpers for the bulk API since its requirement for specific 
formatting and other considerations can make it cumbersome if used directly.

All bulk helpers accept an instance of `{es}` class and an iterable `action` 
(any iterable, can also be a generator, which is ideal in most cases since it 
allows you to index large datasets without the need of loading them into 
memory).

The items in the iterable `action` should be the documents we wish to index in 
several formats. The most common one is the same as returned by `search()`, for 
example:

[source,yml]
----------------------------
{
  '_index': 'index-name',
  '_id': 42,
  '_routing': 5,
  'pipeline': 'my-ingest-pipeline',
  '_source': {
    "title": "Hello World!",
    "body": "..."
  }
}
----------------------------

Alternatively, if `_source` is not present, it pops all metadata fields from 
the doc and use the rest as the document data:

[source,yml]
----------------------------
{
  "_id": 42,
  "_routing": 5,
  "title": "Hello World!",
  "body": "..."
}
----------------------------

The `bulk()` api accepts `index`, `create`, `delete`, and `update` actions. Use 
the `_op_type` field to specify an action (`_op_type` defaults to `index`):

[source,yml]
----------------------------
{
  '_op_type': 'delete',
  '_index': 'index-name',
  '_id': 42,
}
{
  '_op_type': 'update',
  '_index': 'index-name',
  '_id': 42,
  'doc': {'question': 'The life, universe and everything.'}
}
----------------------------


[discrete]
[[scan]]
=== Scan

Simple abstraction on top of the `scroll()` API - a simple iterator that yields 
all hits as returned by underlining scroll requests.

By default scan does not return results in any pre-determined order. To have a 
standard order in the returned documents (either by score or explicit sort 
definition) when scrolling, use `preserve_order=True`. This may be an expensive 
operation and will negate the performance benefits of using `scan`.


[source,py]
----------------------------
scan(es,
    query={"query": {"match": {"title": "python"}}},
    index="orders-*"
)
----------------------------