30 lines
667 B
Markdown
30 lines
667 B
Markdown
|
|
```python title="Python"
|
||
|
|
from kreuzberg import (
|
||
|
|
extract_file_sync,
|
||
|
|
ExtractionConfig,
|
||
|
|
ImagePreprocessingConfig,
|
||
|
|
OcrConfig,
|
||
|
|
TesseractConfig,
|
||
|
|
)
|
||
|
|
|
||
|
|
preprocessing: ImagePreprocessingConfig = ImagePreprocessingConfig(
|
||
|
|
target_dpi=300,
|
||
|
|
denoise=True,
|
||
|
|
deskew=True,
|
||
|
|
contrast_enhance=True,
|
||
|
|
binarization_method="otsu",
|
||
|
|
)
|
||
|
|
|
||
|
|
config: ExtractionConfig = ExtractionConfig(
|
||
|
|
ocr=OcrConfig(
|
||
|
|
backend="tesseract",
|
||
|
|
language="eng",
|
||
|
|
tesseract_config=TesseractConfig(preprocessing=preprocessing),
|
||
|
|
)
|
||
|
|
)
|
||
|
|
|
||
|
|
result = extract_file_sync("document.pdf", config=config)
|
||
|
|
|
||
|
|
print(f"Content length: {len(result.content)} characters")
|
||
|
|
```
|