pyzerox-impacte


Namepyzerox-impacte JSON
Version 0.0.8 PyPI version JSON
download
home_pagehttps://github.com/getomni-ai/zerox.git
Summaryocr documents using vision models from all popular providers like OpenAI, Azure OpenAI, Anthropic, AWS Bedrock etc
upload_time2024-12-10 19:39:55
maintainerNone
docs_urlNone
authorwizenheimer
requires_python<4.0,>=3.11
licenseMIT
keywords ocr document llm
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            ![Hero Image](./examples/heroImage.png)

## Zerox OCR

<a href="https://discord.gg/smg2QfwtJ6">
  <img src="https://github.com/user-attachments/assets/cccc0e9a-e3b2-425e-9b54-e5024681b129" alt="Join us on Discord" width="200px">
</a>

A dead simple way of OCR-ing a document for AI ingestion. Documents are meant to be a visual representation after all. With weird layouts, tables, charts, etc. The vision models just make sense!

The general logic:

- Pass in a file (pdf, docx, image, etc.)
- Convert that file into a series of images
- Pass each image to GPT and ask nicely for Markdown
- Aggregate the responses and return Markdown

Try out the hosted version here: https://getomni.ai/ocr-demo

## Getting Started

Zerox is available as both a Node and Python package.

- [Node Readme](#node-zerox) - [npm package](https://www.npmjs.com/package/zerox)
- [Python Readme](#python-zerox) - [pip package](https://pypi.org/project/py-zerox/)

## Node Zerox

```sh
npm install zerox
```

Zerox uses `graphicsmagick` and `ghostscript` for the pdf => image processing step. These should be pulled automatically, but you may need to manually install.

On linux use:

```
sudo apt-get update
sudo apt-get install -y graphicsmagick
```

## Usage

**With file URL**

```ts
import { zerox } from "zerox";

const result = await zerox({
  filePath: "https://omni-demo-data.s3.amazonaws.com/test/cs101.pdf",
  openaiAPIKey: process.env.OPENAI_API_KEY,
});
```

**From local path**

```ts
import path from "path";
import { zerox } from "zerox";

const result = await zerox({
  filePath: path.resolve(__dirname, "./cs101.pdf"),
  openaiAPIKey: process.env.OPENAI_API_KEY,
});
```

### Options

```ts
const result = await zerox({
  // Required
  filePath: "path/to/file",
  openaiAPIKey: process.env.OPENAI_API_KEY,

  // Optional
  cleanup: true, // Clear images from tmp after run.
  concurrency: 10, // Number of pages to run at a time.
  correctOrientation: true, // True by default, attempts to identify and correct page orientation.
  maintainFormat: false, // Slower but helps maintain consistent formatting.
  maxTesseractWorkers: -1, // Maximum number of tesseract workers. Zerox will start with a lower number and only reach maxTesseractWorkers if needed.
  model: 'gpt-4o-mini' // Model to use (gpt-4o-mini or gpt-4o).
  outputDir: undefined, // Save combined result.md to a file.
  pagesToConvertAsImages: -1, // Page numbers to convert to image as array (e.g. `[1, 2, 3]`) or a number (e.g. `1`). Set to -1 to convert all pages.
  tempDir: "/os/tmp", // Directory to use for temporary files (default: system temp directory).
  trimEdges: true, // True by default, trims pixels from all edges that contain values similar to the given background colour, which defaults to that of the top-left pixel.
});
```

The `maintainFormat` option trys to return the markdown in a consistent format by passing the output of a prior page in as additional context for the next page. This requires the requests to run synchronously, so it's a lot slower. But valuable if your documents have a lot of tabular data, or frequently have tables that cross pages.

```
Request #1 => page_1_image
Request #2 => page_1_markdown + page_2_image
Request #3 => page_2_markdown + page_3_image
```

### Example Output

```js
{
  completionTime: 10038,
  fileName: 'invoice_36258',
  inputTokens: 25543,
  outputTokens: 210,
  pages: [
    {
      content: '# INVOICE # 36258\n' +
        '**Date:** Mar 06 2012  \n' +
        '**Ship Mode:** First Class  \n' +
        '**Balance Due:** $50.10  \n' +
        '## Bill To:\n' +
        'Aaron Bergman  \n' +
        '98103, Seattle,  \n' +
        'Washington, United States  \n' +
        '## Ship To:\n' +
        'Aaron Bergman  \n' +
        '98103, Seattle,  \n' +
        'Washington, United States  \n' +
        '\n' +
        '| Item                                       | Quantity | Rate   | Amount  |\n' +
        '|--------------------------------------------|----------|--------|---------|\n' +
        "| Global Push Button Manager's Chair, Indigo | 1        | $48.71 | $48.71  |\n" +
        '| Chairs, Furniture, FUR-CH-4421             |          |        |         |\n' +
        '\n' +
        '**Subtotal:** $48.71  \n' +
        '**Discount (20%):** $9.74  \n' +
        '**Shipping:** $11.13  \n' +
        '**Total:** $50.10  \n' +
        '---\n' +
        '**Notes:**  \n' +
        'Thanks for your business!  \n' +
        '**Terms:**  \n' +
        'Order ID : CA-2012-AB10015140-40974  ',
      page: 1,
      contentLength: 747
    }
  ]
}
```

## Python Zerox

(Python SDK - supports vision models from different providers like OpenAI, Azure OpenAI, Anthropic, AWS Bedrock etc)

### Installation:

- Install **poppler-utils** on the system, it should be available in path variable
- Install py-zerox:

```sh
pip install py-zerox
```

The `pyzerox.zerox` function is an asynchronous API that performs OCR (Optical Character Recognition) to markdown using vision models. It processes PDF files and converts them into markdown format. Make sure to set up the environment variables for the model and the model provider before using this API.

Refer to the [LiteLLM Documentation](https://docs.litellm.ai/docs/providers) for setting up the environment and passing the correct model name.

### Usage

```python
from pyzerox import zerox
import os
import json
import asyncio

### Model Setup (Use only Vision Models) Refer: https://docs.litellm.ai/docs/providers ###

## placeholder for additional model kwargs which might be required for some models
kwargs = {}

## system prompt to use for the vision model
custom_system_prompt = None

# to override
# custom_system_prompt = "For the below pdf page, do something..something..." ## example

###################### Example for OpenAI ######################
model = "gpt-4o-mini" ## openai model
os.environ["OPENAI_API_KEY"] = "" ## your-api-key


###################### Example for Azure OpenAI ######################
model = "azure/gpt-4o-mini" ## "azure/<your_deployment_name>" -> format <provider>/<model>
os.environ["AZURE_API_KEY"] = "" # "your-azure-api-key"
os.environ["AZURE_API_BASE"] = "" # "https://example-endpoint.openai.azure.com"
os.environ["AZURE_API_VERSION"] = "" # "2023-05-15"


###################### Example for Gemini ######################
model = "gemini/gpt-4o-mini" ## "gemini/<gemini_model>" -> format <provider>/<model>
os.environ['GEMINI_API_KEY'] = "" # your-gemini-api-key


###################### Example for Anthropic ######################
model="claude-3-opus-20240229"
os.environ["ANTHROPIC_API_KEY"] = "" # your-anthropic-api-key

###################### Vertex ai ######################
model = "vertex_ai/gemini-1.5-flash-001" ## "vertex_ai/<model_name>" -> format <provider>/<model>
## GET CREDENTIALS
## RUN ##
# !gcloud auth application-default login - run this to add vertex credentials to your env
## OR ##
file_path = 'path/to/vertex_ai_service_account.json'

# Load the JSON file
with open(file_path, 'r') as file:
    vertex_credentials = json.load(file)

# Convert to JSON string
vertex_credentials_json = json.dumps(vertex_credentials)

vertex_credentials=vertex_credentials_json

## extra args
kwargs = {"vertex_credentials": vertex_credentials}

###################### For other providers refer: https://docs.litellm.ai/docs/providers ######################

# Define main async entrypoint
async def main():
    file_path = "https://omni-demo-data.s3.amazonaws.com/test/cs101.pdf" ## local filepath and file URL supported

    ## process only some pages or all
    select_pages = None ## None for all, but could be int or list(int) page numbers (1 indexed)

    output_dir = "./output_test" ## directory to save the consolidated markdown file
    result = await zerox(file_path=file_path, model=model, output_dir=output_dir,
                        custom_system_prompt=custom_system_prompt,select_pages=select_pages, **kwargs)
    return result


# run the main function:
result = asyncio.run(main())

# print markdown result
print(result)
```

### Parameters

```python
async def zerox(
    cleanup: bool = True,
    concurrency: int = 10,
    file_path: Optional[str] = "",
    maintain_format: bool = False,
    model: str = "gpt-4o-mini",
    output_dir: Optional[str] = None,
    temp_dir: Optional[str] = None,
    custom_system_prompt: Optional[str] = None,
    select_pages: Optional[Union[int, Iterable[int]]] = None,
    **kwargs
) -> ZeroxOutput:
  ...
```

Parameters

- **cleanup** (bool, optional):
  Whether to clean up temporary files after processing. Defaults to True.
- **concurrency** (int, optional):
  The number of concurrent processes to run. Defaults to 10.
- **file_path** (Optional[str], optional):
  The path to the PDF file to process. Defaults to an empty string.
- **maintain_format** (bool, optional):
  Whether to maintain the format from the previous page. Defaults to False.
- **model** (str, optional):
  The model to use for generating completions. Defaults to "gpt-4o-mini".
  Refer to LiteLLM Providers for the correct model name, as it may differ depending on the provider.
- **output_dir** (Optional[str], optional):
  The directory to save the markdown output. Defaults to None.
- **temp_dir** (str, optional):
  The directory to store temporary files, defaults to some named folder in system's temp directory. If already exists, the contents will be deleted before zerox uses it.
- **custom_system_prompt** (str, optional):
  The system prompt to use for the model, this overrides the default system prompt of zerox.Generally it is not required unless you want some specific behaviour. When set, it will raise a friendly warning. Defaults to None.
- **select_pages** (Optional[Union[int, Iterable[int]]], optional):
  Pages to process, can be a single page number or an iterable of page numbers, Defaults to None
- **kwargs** (dict, optional):
  Additional keyword arguments to pass to the litellm.completion method.
  Refer to the LiteLLM Documentation and Completion Input for details.

Returns

- ZeroxOutput:
  Contains the markdown content generated by the model and also some metadata (refer below).

### Example Output (Output from "azure/gpt-4o-mini"):

`Note: The output is mannually wrapped for this documentation for better readability.`

````Python
ZeroxOutput(
    completion_time=9432.975,
    file_name='cs101',
    input_tokens=36877,
    output_tokens=515,
    pages=[
        Page(
            content='| Type    | Description                          | Wrapper Class |\n' +
                    '|---------|--------------------------------------|---------------|\n' +
                    '| byte    | 8-bit signed 2s complement integer   | Byte          |\n' +
                    '| short   | 16-bit signed 2s complement integer  | Short         |\n' +
                    '| int     | 32-bit signed 2s complement integer  | Integer       |\n' +
                    '| long    | 64-bit signed 2s complement integer  | Long          |\n' +
                    '| float   | 32-bit IEEE 754 floating point number| Float         |\n' +
                    '| double  | 64-bit floating point number         | Double        |\n' +
                    '| boolean | may be set to true or false          | Boolean       |\n' +
                    '| char    | 16-bit Unicode (UTF-16) character    | Character     |\n\n' +
                    'Table 26.2.: Primitive types in Java\n\n' +
                    '### 26.3.1. Declaration & Assignment\n\n' +
                    'Java is a statically typed language meaning that all variables must be declared before you can use ' +
                    'them or refer to them. In addition, when declaring a variable, you must specify both its type and ' +
                    'its identifier. For example:\n\n' +
                    '```java\n' +
                    'int numUnits;\n' +
                    'double costPerUnit;\n' +
                    'char firstInitial;\n' +
                    'boolean isStudent;\n' +
                    '```\n\n' +
                    'Each declaration specifies the variable’s type followed by the identifier and ending with a ' +
                    'semicolon. The identifier rules are fairly standard: a name can consist of lowercase and ' +
                    'uppercase alphabetic characters, numbers, and underscores but may not begin with a numeric ' +
                    'character. We adopt the modern camelCasing naming convention for variables in our code. In ' +
                    'general, variables must be assigned a value before you can use them in an expression. You do not ' +
                    'have to immediately assign a value when you declare them (though it is good practice), but some ' +
                    'value must be assigned before they can be used or the compiler will issue an error.\n\n' +
                    'The assignment operator is a single equal sign, `=` and is a right-to-left assignment. That is, ' +
                    'the variable that we wish to assign the value to appears on the left-hand-side while the value ' +
                    '(literal, variable or expression) is on the right-hand-side. Using our variables from before, ' +
                    'we can assign them values:\n\n' +
                    '> 2 Instance variables, that is variables declared as part of an object do have default values. ' +
                    'For objects, the default is `null`, for all numeric types, zero is the default value. For the ' +
                    'boolean type, `false` is the default, and the default char value is `\\0`, the null-terminating ' +
                    'character (zero in the ASCII table).',
            content_length=2333,
            page=1
        )
    ]
)
````

## Supported File Types:

We use a combination of `libreoffice` and `graphicsmagick` to do document => image conversion. For non-image / non-pdf files, we use libreoffice to convert that file to a pdf, and then to an image.

```js
[
  "pdf", // Portable Document Format
  "doc", // Microsoft Word 97-2003
  "docx", // Microsoft Word 2007-2019
  "odt", // OpenDocument Text
  "ott", // OpenDocument Text Template
  "rtf", // Rich Text Format
  "txt", // Plain Text
  "html", // HTML Document
  "htm", // HTML Document (alternative extension)
  "xml", // XML Document
  "wps", // Microsoft Works Word Processor
  "wpd", // WordPerfect Document
  "xls", // Microsoft Excel 97-2003
  "xlsx", // Microsoft Excel 2007-2019
  "ods", // OpenDocument Spreadsheet
  "ots", // OpenDocument Spreadsheet Template
  "csv", // Comma-Separated Values
  "tsv", // Tab-Separated Values
  "ppt", // Microsoft PowerPoint 97-2003
  "pptx", // Microsoft PowerPoint 2007-2019
  "odp", // OpenDocument Presentation
  "otp", // OpenDocument Presentation Template
];
```

## Credits

- [Litellm](https://github.com/BerriAI/litellm): https://github.com/BerriAI/litellm | This powers our python sdk to support all popular vision models from different providers.

### License

This project is licensed under the MIT License.

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/getomni-ai/zerox.git",
    "name": "pyzerox-impacte",
    "maintainer": null,
    "docs_url": null,
    "requires_python": "<4.0,>=3.11",
    "maintainer_email": null,
    "keywords": "ocr, document, llm",
    "author": "wizenheimer",
    "author_email": null,
    "download_url": "https://files.pythonhosted.org/packages/07/5d/57346b7bbbc811bf42d514b374adb27022aa627226477e0b80cd69acf8a0/pyzerox_impacte-0.0.8.tar.gz",
    "platform": null,
    "description": "![Hero Image](./examples/heroImage.png)\n\n## Zerox OCR\n\n<a href=\"https://discord.gg/smg2QfwtJ6\">\n  <img src=\"https://github.com/user-attachments/assets/cccc0e9a-e3b2-425e-9b54-e5024681b129\" alt=\"Join us on Discord\" width=\"200px\">\n</a>\n\nA dead simple way of OCR-ing a document for AI ingestion. Documents are meant to be a visual representation after all. With weird layouts, tables, charts, etc. The vision models just make sense!\n\nThe general logic:\n\n- Pass in a file (pdf, docx, image, etc.)\n- Convert that file into a series of images\n- Pass each image to GPT and ask nicely for Markdown\n- Aggregate the responses and return Markdown\n\nTry out the hosted version here: https://getomni.ai/ocr-demo\n\n## Getting Started\n\nZerox is available as both a Node and Python package.\n\n- [Node Readme](#node-zerox) - [npm package](https://www.npmjs.com/package/zerox)\n- [Python Readme](#python-zerox) - [pip package](https://pypi.org/project/py-zerox/)\n\n## Node Zerox\n\n```sh\nnpm install zerox\n```\n\nZerox uses `graphicsmagick` and `ghostscript` for the pdf => image processing step. These should be pulled automatically, but you may need to manually install.\n\nOn linux use:\n\n```\nsudo apt-get update\nsudo apt-get install -y graphicsmagick\n```\n\n## Usage\n\n**With file URL**\n\n```ts\nimport { zerox } from \"zerox\";\n\nconst result = await zerox({\n  filePath: \"https://omni-demo-data.s3.amazonaws.com/test/cs101.pdf\",\n  openaiAPIKey: process.env.OPENAI_API_KEY,\n});\n```\n\n**From local path**\n\n```ts\nimport path from \"path\";\nimport { zerox } from \"zerox\";\n\nconst result = await zerox({\n  filePath: path.resolve(__dirname, \"./cs101.pdf\"),\n  openaiAPIKey: process.env.OPENAI_API_KEY,\n});\n```\n\n### Options\n\n```ts\nconst result = await zerox({\n  // Required\n  filePath: \"path/to/file\",\n  openaiAPIKey: process.env.OPENAI_API_KEY,\n\n  // Optional\n  cleanup: true, // Clear images from tmp after run.\n  concurrency: 10, // Number of pages to run at a time.\n  correctOrientation: true, // True by default, attempts to identify and correct page orientation.\n  maintainFormat: false, // Slower but helps maintain consistent formatting.\n  maxTesseractWorkers: -1, // Maximum number of tesseract workers. Zerox will start with a lower number and only reach maxTesseractWorkers if needed.\n  model: 'gpt-4o-mini' // Model to use (gpt-4o-mini or gpt-4o).\n  outputDir: undefined, // Save combined result.md to a file.\n  pagesToConvertAsImages: -1, // Page numbers to convert to image as array (e.g. `[1, 2, 3]`) or a number (e.g. `1`). Set to -1 to convert all pages.\n  tempDir: \"/os/tmp\", // Directory to use for temporary files (default: system temp directory).\n  trimEdges: true, // True by default, trims pixels from all edges that contain values similar to the given background colour, which defaults to that of the top-left pixel.\n});\n```\n\nThe `maintainFormat` option trys to return the markdown in a consistent format by passing the output of a prior page in as additional context for the next page. This requires the requests to run synchronously, so it's a lot slower. But valuable if your documents have a lot of tabular data, or frequently have tables that cross pages.\n\n```\nRequest #1 => page_1_image\nRequest #2 => page_1_markdown + page_2_image\nRequest #3 => page_2_markdown + page_3_image\n```\n\n### Example Output\n\n```js\n{\n  completionTime: 10038,\n  fileName: 'invoice_36258',\n  inputTokens: 25543,\n  outputTokens: 210,\n  pages: [\n    {\n      content: '# INVOICE # 36258\\n' +\n        '**Date:** Mar 06 2012  \\n' +\n        '**Ship Mode:** First Class  \\n' +\n        '**Balance Due:** $50.10  \\n' +\n        '## Bill To:\\n' +\n        'Aaron Bergman  \\n' +\n        '98103, Seattle,  \\n' +\n        'Washington, United States  \\n' +\n        '## Ship To:\\n' +\n        'Aaron Bergman  \\n' +\n        '98103, Seattle,  \\n' +\n        'Washington, United States  \\n' +\n        '\\n' +\n        '| Item                                       | Quantity | Rate   | Amount  |\\n' +\n        '|--------------------------------------------|----------|--------|---------|\\n' +\n        \"| Global Push Button Manager's Chair, Indigo | 1        | $48.71 | $48.71  |\\n\" +\n        '| Chairs, Furniture, FUR-CH-4421             |          |        |         |\\n' +\n        '\\n' +\n        '**Subtotal:** $48.71  \\n' +\n        '**Discount (20%):** $9.74  \\n' +\n        '**Shipping:** $11.13  \\n' +\n        '**Total:** $50.10  \\n' +\n        '---\\n' +\n        '**Notes:**  \\n' +\n        'Thanks for your business!  \\n' +\n        '**Terms:**  \\n' +\n        'Order ID : CA-2012-AB10015140-40974  ',\n      page: 1,\n      contentLength: 747\n    }\n  ]\n}\n```\n\n## Python Zerox\n\n(Python SDK - supports vision models from different providers like OpenAI, Azure OpenAI, Anthropic, AWS Bedrock etc)\n\n### Installation:\n\n- Install **poppler-utils** on the system, it should be available in path variable\n- Install py-zerox:\n\n```sh\npip install py-zerox\n```\n\nThe `pyzerox.zerox` function is an asynchronous API that performs OCR (Optical Character Recognition) to markdown using vision models. It processes PDF files and converts them into markdown format. Make sure to set up the environment variables for the model and the model provider before using this API.\n\nRefer to the [LiteLLM Documentation](https://docs.litellm.ai/docs/providers) for setting up the environment and passing the correct model name.\n\n### Usage\n\n```python\nfrom pyzerox import zerox\nimport os\nimport json\nimport asyncio\n\n### Model Setup (Use only Vision Models) Refer: https://docs.litellm.ai/docs/providers ###\n\n## placeholder for additional model kwargs which might be required for some models\nkwargs = {}\n\n## system prompt to use for the vision model\ncustom_system_prompt = None\n\n# to override\n# custom_system_prompt = \"For the below pdf page, do something..something...\" ## example\n\n###################### Example for OpenAI ######################\nmodel = \"gpt-4o-mini\" ## openai model\nos.environ[\"OPENAI_API_KEY\"] = \"\" ## your-api-key\n\n\n###################### Example for Azure OpenAI ######################\nmodel = \"azure/gpt-4o-mini\" ## \"azure/<your_deployment_name>\" -> format <provider>/<model>\nos.environ[\"AZURE_API_KEY\"] = \"\" # \"your-azure-api-key\"\nos.environ[\"AZURE_API_BASE\"] = \"\" # \"https://example-endpoint.openai.azure.com\"\nos.environ[\"AZURE_API_VERSION\"] = \"\" # \"2023-05-15\"\n\n\n###################### Example for Gemini ######################\nmodel = \"gemini/gpt-4o-mini\" ## \"gemini/<gemini_model>\" -> format <provider>/<model>\nos.environ['GEMINI_API_KEY'] = \"\" # your-gemini-api-key\n\n\n###################### Example for Anthropic ######################\nmodel=\"claude-3-opus-20240229\"\nos.environ[\"ANTHROPIC_API_KEY\"] = \"\" # your-anthropic-api-key\n\n###################### Vertex ai ######################\nmodel = \"vertex_ai/gemini-1.5-flash-001\" ## \"vertex_ai/<model_name>\" -> format <provider>/<model>\n## GET CREDENTIALS\n## RUN ##\n# !gcloud auth application-default login - run this to add vertex credentials to your env\n## OR ##\nfile_path = 'path/to/vertex_ai_service_account.json'\n\n# Load the JSON file\nwith open(file_path, 'r') as file:\n    vertex_credentials = json.load(file)\n\n# Convert to JSON string\nvertex_credentials_json = json.dumps(vertex_credentials)\n\nvertex_credentials=vertex_credentials_json\n\n## extra args\nkwargs = {\"vertex_credentials\": vertex_credentials}\n\n###################### For other providers refer: https://docs.litellm.ai/docs/providers ######################\n\n# Define main async entrypoint\nasync def main():\n    file_path = \"https://omni-demo-data.s3.amazonaws.com/test/cs101.pdf\" ## local filepath and file URL supported\n\n    ## process only some pages or all\n    select_pages = None ## None for all, but could be int or list(int) page numbers (1 indexed)\n\n    output_dir = \"./output_test\" ## directory to save the consolidated markdown file\n    result = await zerox(file_path=file_path, model=model, output_dir=output_dir,\n                        custom_system_prompt=custom_system_prompt,select_pages=select_pages, **kwargs)\n    return result\n\n\n# run the main function:\nresult = asyncio.run(main())\n\n# print markdown result\nprint(result)\n```\n\n### Parameters\n\n```python\nasync def zerox(\n    cleanup: bool = True,\n    concurrency: int = 10,\n    file_path: Optional[str] = \"\",\n    maintain_format: bool = False,\n    model: str = \"gpt-4o-mini\",\n    output_dir: Optional[str] = None,\n    temp_dir: Optional[str] = None,\n    custom_system_prompt: Optional[str] = None,\n    select_pages: Optional[Union[int, Iterable[int]]] = None,\n    **kwargs\n) -> ZeroxOutput:\n  ...\n```\n\nParameters\n\n- **cleanup** (bool, optional):\n  Whether to clean up temporary files after processing. Defaults to True.\n- **concurrency** (int, optional):\n  The number of concurrent processes to run. Defaults to 10.\n- **file_path** (Optional[str], optional):\n  The path to the PDF file to process. Defaults to an empty string.\n- **maintain_format** (bool, optional):\n  Whether to maintain the format from the previous page. Defaults to False.\n- **model** (str, optional):\n  The model to use for generating completions. Defaults to \"gpt-4o-mini\".\n  Refer to LiteLLM Providers for the correct model name, as it may differ depending on the provider.\n- **output_dir** (Optional[str], optional):\n  The directory to save the markdown output. Defaults to None.\n- **temp_dir** (str, optional):\n  The directory to store temporary files, defaults to some named folder in system's temp directory. If already exists, the contents will be deleted before zerox uses it.\n- **custom_system_prompt** (str, optional):\n  The system prompt to use for the model, this overrides the default system prompt of zerox.Generally it is not required unless you want some specific behaviour. When set, it will raise a friendly warning. Defaults to None.\n- **select_pages** (Optional[Union[int, Iterable[int]]], optional):\n  Pages to process, can be a single page number or an iterable of page numbers, Defaults to None\n- **kwargs** (dict, optional):\n  Additional keyword arguments to pass to the litellm.completion method.\n  Refer to the LiteLLM Documentation and Completion Input for details.\n\nReturns\n\n- ZeroxOutput:\n  Contains the markdown content generated by the model and also some metadata (refer below).\n\n### Example Output (Output from \"azure/gpt-4o-mini\"):\n\n`Note: The output is mannually wrapped for this documentation for better readability.`\n\n````Python\nZeroxOutput(\n    completion_time=9432.975,\n    file_name='cs101',\n    input_tokens=36877,\n    output_tokens=515,\n    pages=[\n        Page(\n            content='| Type    | Description                          | Wrapper Class |\\n' +\n                    '|---------|--------------------------------------|---------------|\\n' +\n                    '| byte    | 8-bit signed 2s complement integer   | Byte          |\\n' +\n                    '| short   | 16-bit signed 2s complement integer  | Short         |\\n' +\n                    '| int     | 32-bit signed 2s complement integer  | Integer       |\\n' +\n                    '| long    | 64-bit signed 2s complement integer  | Long          |\\n' +\n                    '| float   | 32-bit IEEE 754 floating point number| Float         |\\n' +\n                    '| double  | 64-bit floating point number         | Double        |\\n' +\n                    '| boolean | may be set to true or false          | Boolean       |\\n' +\n                    '| char    | 16-bit Unicode (UTF-16) character    | Character     |\\n\\n' +\n                    'Table 26.2.: Primitive types in Java\\n\\n' +\n                    '### 26.3.1. Declaration & Assignment\\n\\n' +\n                    'Java is a statically typed language meaning that all variables must be declared before you can use ' +\n                    'them or refer to them. In addition, when declaring a variable, you must specify both its type and ' +\n                    'its identifier. For example:\\n\\n' +\n                    '```java\\n' +\n                    'int numUnits;\\n' +\n                    'double costPerUnit;\\n' +\n                    'char firstInitial;\\n' +\n                    'boolean isStudent;\\n' +\n                    '```\\n\\n' +\n                    'Each declaration specifies the variable\u2019s type followed by the identifier and ending with a ' +\n                    'semicolon. The identifier rules are fairly standard: a name can consist of lowercase and ' +\n                    'uppercase alphabetic characters, numbers, and underscores but may not begin with a numeric ' +\n                    'character. We adopt the modern camelCasing naming convention for variables in our code. In ' +\n                    'general, variables must be assigned a value before you can use them in an expression. You do not ' +\n                    'have to immediately assign a value when you declare them (though it is good practice), but some ' +\n                    'value must be assigned before they can be used or the compiler will issue an error.\\n\\n' +\n                    'The assignment operator is a single equal sign, `=` and is a right-to-left assignment. That is, ' +\n                    'the variable that we wish to assign the value to appears on the left-hand-side while the value ' +\n                    '(literal, variable or expression) is on the right-hand-side. Using our variables from before, ' +\n                    'we can assign them values:\\n\\n' +\n                    '> 2 Instance variables, that is variables declared as part of an object do have default values. ' +\n                    'For objects, the default is `null`, for all numeric types, zero is the default value. For the ' +\n                    'boolean type, `false` is the default, and the default char value is `\\\\0`, the null-terminating ' +\n                    'character (zero in the ASCII table).',\n            content_length=2333,\n            page=1\n        )\n    ]\n)\n````\n\n## Supported File Types:\n\nWe use a combination of `libreoffice` and `graphicsmagick` to do document => image conversion. For non-image / non-pdf files, we use libreoffice to convert that file to a pdf, and then to an image.\n\n```js\n[\n  \"pdf\", // Portable Document Format\n  \"doc\", // Microsoft Word 97-2003\n  \"docx\", // Microsoft Word 2007-2019\n  \"odt\", // OpenDocument Text\n  \"ott\", // OpenDocument Text Template\n  \"rtf\", // Rich Text Format\n  \"txt\", // Plain Text\n  \"html\", // HTML Document\n  \"htm\", // HTML Document (alternative extension)\n  \"xml\", // XML Document\n  \"wps\", // Microsoft Works Word Processor\n  \"wpd\", // WordPerfect Document\n  \"xls\", // Microsoft Excel 97-2003\n  \"xlsx\", // Microsoft Excel 2007-2019\n  \"ods\", // OpenDocument Spreadsheet\n  \"ots\", // OpenDocument Spreadsheet Template\n  \"csv\", // Comma-Separated Values\n  \"tsv\", // Tab-Separated Values\n  \"ppt\", // Microsoft PowerPoint 97-2003\n  \"pptx\", // Microsoft PowerPoint 2007-2019\n  \"odp\", // OpenDocument Presentation\n  \"otp\", // OpenDocument Presentation Template\n];\n```\n\n## Credits\n\n- [Litellm](https://github.com/BerriAI/litellm): https://github.com/BerriAI/litellm | This powers our python sdk to support all popular vision models from different providers.\n\n### License\n\nThis project is licensed under the MIT License.\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "ocr documents using vision models from all popular providers like OpenAI, Azure OpenAI, Anthropic, AWS Bedrock etc",
    "version": "0.0.8",
    "project_urls": {
        "Documentation": "https://github.com/getomni-ai/zerox",
        "Homepage": "https://github.com/getomni-ai/zerox.git",
        "Repository": "https://github.com/getomni-ai/zerox.git"
    },
    "split_keywords": [
        "ocr",
        " document",
        " llm"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "59375bbff778f6420b95eebb4797fc14b97834c3860ca8ae08376d228e96be91",
                "md5": "fa96f64aa845376aa429c0b1f4fc51cf",
                "sha256": "fef789bb6f2dfefca12fcd1d2d4498934aa7507924c91421419b3a49c493a822"
            },
            "downloads": -1,
            "filename": "pyzerox_impacte-0.0.8-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "fa96f64aa845376aa429c0b1f4fc51cf",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<4.0,>=3.11",
            "size": 22857,
            "upload_time": "2024-12-10T19:39:51",
            "upload_time_iso_8601": "2024-12-10T19:39:51.366012Z",
            "url": "https://files.pythonhosted.org/packages/59/37/5bbff778f6420b95eebb4797fc14b97834c3860ca8ae08376d228e96be91/pyzerox_impacte-0.0.8-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "075d57346b7bbbc811bf42d514b374adb27022aa627226477e0b80cd69acf8a0",
                "md5": "31fc2aed227857e604b8b55d65e93bc7",
                "sha256": "12b2e5b0ca641f0ad1e06c220457cfb88cd7df73080bf200656e055837f8e9f5"
            },
            "downloads": -1,
            "filename": "pyzerox_impacte-0.0.8.tar.gz",
            "has_sig": false,
            "md5_digest": "31fc2aed227857e604b8b55d65e93bc7",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": "<4.0,>=3.11",
            "size": 17407,
            "upload_time": "2024-12-10T19:39:55",
            "upload_time_iso_8601": "2024-12-10T19:39:55.330197Z",
            "url": "https://files.pythonhosted.org/packages/07/5d/57346b7bbbc811bf42d514b374adb27022aa627226477e0b80cd69acf8a0/pyzerox_impacte-0.0.8.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-12-10 19:39:55",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "getomni-ai",
    "github_project": "zerox",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "pyzerox-impacte"
}
        
Elapsed time: 0.95702s