Multi term vectors API

Multi term vectors API

Retrieves multiple term vectors with a single request.

  1. resp = client.mtermvectors(
  2. docs=[
  3. {
  4. "_index": "my-index-000001",
  5. "_id": "2",
  6. "term_statistics": True
  7. },
  8. {
  9. "_index": "my-index-000001",
  10. "_id": "1",
  11. "fields": [
  12. "message"
  13. ]
  14. }
  15. ],
  16. )
  17. print(resp)
  1. response = client.mtermvectors(
  2. body: {
  3. docs: [
  4. {
  5. _index: 'my-index-000001',
  6. _id: '2',
  7. term_statistics: true
  8. },
  9. {
  10. _index: 'my-index-000001',
  11. _id: '1',
  12. fields: [
  13. 'message'
  14. ]
  15. }
  16. ]
  17. }
  18. )
  19. puts response
  1. const response = await client.mtermvectors({
  2. docs: [
  3. {
  4. _index: "my-index-000001",
  5. _id: "2",
  6. term_statistics: true,
  7. },
  8. {
  9. _index: "my-index-000001",
  10. _id: "1",
  11. fields: ["message"],
  12. },
  13. ],
  14. });
  15. console.log(response);
  1. POST /_mtermvectors
  2. {
  3. "docs": [
  4. {
  5. "_index": "my-index-000001",
  6. "_id": "2",
  7. "term_statistics": true
  8. },
  9. {
  10. "_index": "my-index-000001",
  11. "_id": "1",
  12. "fields": [
  13. "message"
  14. ]
  15. }
  16. ]
  17. }

Request

POST /_mtermvectors

POST /<index>/_mtermvectors

Prerequisites

  • If the Elasticsearch security features are enabled, you must have the read index privilege for the target index or index alias.

Description

You can specify existing documents by index and ID or provide artificial documents in the body of the request. You can specify the index in the request body or request URI.

The response contains a docs array with all the fetched termvectors. Each element has the structure provided by the termvectors API.

See the termvectors API for more information about the information that can be included in the response.

Path parameters

<index>

(Optional, string) Name of the index that contains the documents.

Query parameters

fields

(Optional, string) Comma-separated list or wildcard expressions of fields to include in the statistics.

Used as the default list unless a specific field list is provided in the completion_fields or fielddata_fields parameters.

field_statistics

(Optional, Boolean) If true, the response includes the document count, sum of document frequencies, and sum of total term frequencies. Defaults to true.

<offsets>

(Optional, Boolean) If true, the response includes term offsets. Defaults to true.

payloads

(Optional, Boolean) If true, the response includes term payloads. Defaults to true.

positions

(Optional, Boolean) If true, the response includes term positions. Defaults to true.

preference

(Optional, string) Specifies the node or shard the operation should be performed on. Random by default.

routing

(Optional, string) Custom value used to route operations to a specific shard.

realtime

(Optional, Boolean) If true, the request is real-time as opposed to near-real-time. Defaults to true. See Realtime.

term_statistics

(Optional, Boolean) If true, the response includes term frequency and document frequency. Defaults to false.

version

(Optional, Boolean) If true, returns the document version as part of a hit.

version_type

(Optional, enum) Specific version type: external, external_gte.

Examples

If you specify an index in the request URI, the index does not need to be specified for each documents in the request body:

  1. resp = client.mtermvectors(
  2. index="my-index-000001",
  3. docs=[
  4. {
  5. "_id": "2",
  6. "fields": [
  7. "message"
  8. ],
  9. "term_statistics": True
  10. },
  11. {
  12. "_id": "1"
  13. }
  14. ],
  15. )
  16. print(resp)
  1. response = client.mtermvectors(
  2. index: 'my-index-000001',
  3. body: {
  4. docs: [
  5. {
  6. _id: '2',
  7. fields: [
  8. 'message'
  9. ],
  10. term_statistics: true
  11. },
  12. {
  13. _id: '1'
  14. }
  15. ]
  16. }
  17. )
  18. puts response
  1. const response = await client.mtermvectors({
  2. index: "my-index-000001",
  3. docs: [
  4. {
  5. _id: "2",
  6. fields: ["message"],
  7. term_statistics: true,
  8. },
  9. {
  10. _id: "1",
  11. },
  12. ],
  13. });
  14. console.log(response);
  1. POST /my-index-000001/_mtermvectors
  2. {
  3. "docs": [
  4. {
  5. "_id": "2",
  6. "fields": [
  7. "message"
  8. ],
  9. "term_statistics": true
  10. },
  11. {
  12. "_id": "1"
  13. }
  14. ]
  15. }

If all requested documents are in same index and the parameters are the same, you can use the following simplified syntax:

  1. resp = client.mtermvectors(
  2. index="my-index-000001",
  3. ids=[
  4. "1",
  5. "2"
  6. ],
  7. parameters={
  8. "fields": [
  9. "message"
  10. ],
  11. "term_statistics": True
  12. },
  13. )
  14. print(resp)
  1. response = client.mtermvectors(
  2. index: 'my-index-000001',
  3. body: {
  4. ids: [
  5. '1',
  6. '2'
  7. ],
  8. parameters: {
  9. fields: [
  10. 'message'
  11. ],
  12. term_statistics: true
  13. }
  14. }
  15. )
  16. puts response
  1. const response = await client.mtermvectors({
  2. index: "my-index-000001",
  3. ids: ["1", "2"],
  4. parameters: {
  5. fields: ["message"],
  6. term_statistics: true,
  7. },
  8. });
  9. console.log(response);
  1. POST /my-index-000001/_mtermvectors
  2. {
  3. "ids": [ "1", "2" ],
  4. "parameters": {
  5. "fields": [
  6. "message"
  7. ],
  8. "term_statistics": true
  9. }
  10. }

Artificial documents

You can also use mtermvectors to generate term vectors for artificial documents provided in the body of the request. The mapping used is determined by the specified _index.

  1. resp = client.mtermvectors(
  2. docs=[
  3. {
  4. "_index": "my-index-000001",
  5. "doc": {
  6. "message": "test test test"
  7. }
  8. },
  9. {
  10. "_index": "my-index-000001",
  11. "doc": {
  12. "message": "Another test ..."
  13. }
  14. }
  15. ],
  16. )
  17. print(resp)
  1. response = client.mtermvectors(
  2. body: {
  3. docs: [
  4. {
  5. _index: 'my-index-000001',
  6. doc: {
  7. message: 'test test test'
  8. }
  9. },
  10. {
  11. _index: 'my-index-000001',
  12. doc: {
  13. message: 'Another test ...'
  14. }
  15. }
  16. ]
  17. }
  18. )
  19. puts response
  1. const response = await client.mtermvectors({
  2. docs: [
  3. {
  4. _index: "my-index-000001",
  5. doc: {
  6. message: "test test test",
  7. },
  8. },
  9. {
  10. _index: "my-index-000001",
  11. doc: {
  12. message: "Another test ...",
  13. },
  14. },
  15. ],
  16. });
  17. console.log(response);
  1. POST /_mtermvectors
  2. {
  3. "docs": [
  4. {
  5. "_index": "my-index-000001",
  6. "doc" : {
  7. "message" : "test test test"
  8. }
  9. },
  10. {
  11. "_index": "my-index-000001",
  12. "doc" : {
  13. "message" : "Another test ..."
  14. }
  15. }
  16. ]
  17. }