---
title: "OpenAILanguagesDetectionSettings"
canonical_url: "https://www.nutrient.io/api/python/settings/advanced/vision/open-ai-languages-detection-settings/"
md_url: "https://www.nutrient.io/api/python/settings/advanced/vision/open-ai-languages-detection-settings.md"
last_updated: "2026-06-12T15:43:20.744Z"
description: "Settings for OpenAILanguagesDetection. Values fall back through three levels: document → SDK → built-in default."
---

Settings for OpenAILanguagesDetection. Values fall back through three levels: document → SDK → built-in default. Writes target the document only when set on a document's settings, otherwise the SDK globally when set on SdkSettings.

**Tags:** `Advanced`, `Vision`

```python

from nutrient_sdk import OpenAILanguagesDetectionSettings

```

## Construction

`OpenAILanguagesDetectionSettings` is accessed through a [`Document`](/api/python/document/) instance for per-document overrides, or via [`SdkSettings`](/api/python/settings/document/sdk-settings/) for SDK-wide defaults.

```python

# Per-document override

with Document.open("input.pdf") as doc:
    settings = doc.settings.open_ai_languages_detection_settings
    settings.some_field = new_value          # mutate fields directly

# SDK-wide default (applies to all documents)

SdkSettings.open_ai_languages_detection_settings.some_field = new_value

```

Settings are configured by writing to fields on the returned object. The settings property itself cannot be reassigned — `doc.settings.open_ai_languages_detection_settings = other_settings` is rejected.

## Properties

### api_endpoint

```python

@property
def api_endpoint(self) -> str

@api_endpoint.setter
def api_endpoint(self, value: str) -> None

```

OpenAI API endpoint URL.

**Type:** `str`

**Default:** `"https://api.openai.com/v1"`

---

### api_key

```python

@property
def api_key(self) -> str

@api_key.setter
def api_key(self, value: str) -> None

```

OpenAI API key for authentication.

**Type:** `str`

**Default:** `string.Empty`

---

### detail

```python

@property
def detail(self) -> str

@detail.setter
def detail(self, value: str) -> None

```

Detail level for image analysis (low, high, auto).

**Type:** `str`

**Default:** `"low"`

---

### max_tokens

```python

@property
def max_tokens(self) -> int

@max_tokens.setter
def max_tokens(self, value: int) -> None

```

Maximum number of tokens in the response.

**Type:** `int`

**Default:** `500`

---

### model

```python

@property
def model(self) -> str

@model.setter
def model(self, value: str) -> None

```

Model to use for language detection (e.g., "gpt-4o-mini").

**Type:** `str`

**Default:** `"gpt-4o-mini"`

---

### temperature

```python

@property
def temperature(self) -> float

@temperature.setter
def temperature(self, value: float) -> None

```

Temperature for response generation (0.0 to 1.0). Lower values produce more deterministic outputs.

**Type:** `float`

**Default:** `0.0`

---

---

## Related pages

- [Per-document override](/api/python/settings/advanced/vision/ai-processing-settings.md)
- [Per-document override](/api/python/settings/advanced/vision/custom-vlm-api-settings.md)
- [Per-document override](/api/python/settings/advanced/vision/form-labeling-settings.md)
- [Per-document override](/api/python/settings/advanced/vision/finalizer-settings.md)
- [Per-document override](/api/python/settings/advanced/vision/form-recognition-settings.md)
- [Vision](/api/python/settings/advanced/vision.md)
- [Per-document override](/api/python/settings/advanced/vision/ocr-settings.md)
- [Per-document override](/api/python/settings/advanced/vision/inference-layout-settings.md)
- [Per-document override](/api/python/settings/advanced/vision/open-ai-picture-alt-settings.md)
- [Per-document override](/api/python/settings/advanced/vision/reading-order-settings.md)
- [Per-document override](/api/python/settings/advanced/vision/segmenter-settings.md)
- [Per-document override](/api/python/settings/advanced/vision/words-detection-settings.md)

