Skip to main content

Convert text to datasets

Project description

txt2dataset

A package for building, standardizing and validating datasets using language models. Supports normal API as well as batch API.

Models Supported

  • Gemini - Make sure to set your "GEMINI_API_KEY" to environment.
  • OpenRouter - "OPENROUTER_API_KEY"
  • OpenAI - "OPENAI_API_KEY"
  • Custom OpenAI Endpoint - such as via Azure.

Installation

pip install txt2dataset

Usage

Schema

from pydantic import BaseModel
from typing import Optional, List
from datetime import datetime

class SingleDividend(BaseModel):
    dividend_per_share: float
    payment_date: Optional[datetime] = None
    record_date: Optional[datetime] = None
    stock_type_specified: Optional[str] = None

class DividendExtraction(BaseModel):
    info_found: bool
    data: List[SingleDividend] = []

Entries

Entries consist of an identifier and the text to be structured.

entries = [{'id':0, 'context':
    """First Business Financial Services, Inc. (the "Company") issued a press release today 
    announcing that the Company's Board of Directors declared a quarterly dividend of $0.18 
    per share on April 30, 2021, unchanged compared to the last quarterly dividend per share. 
    The dividend is payable on May 24, 2021 to shareholders of record on May 10, 2021. 
    Also on July 12, 2020 there was a payable dividend of $0.15 per share to shareholders 
    of record on July 1st, 2020."""},

    {"id":1,"context": """XYZ Corp declared a dividend of $0.25 per share, payable June 15, 2021 
    to shareholders of record as of June 1, 2021."""}
]

Prompt

Choose a prompt such as:

prompt = "Extract ALL dividend information from this text"

Dataset Builder

Choose the requests per minute that work for your api key and model.

from txt2dataset import GeminiAPIBuilder

builder = GeminiAPIBuilder()
results, errors = builder.build(prompt=prompt, schema=DividendExtraction, model="gemini-2.5-flash-lite",
               entries=entries, rpm=4_000, tpm=4_000_000, rpm_threshold=0.75, tpm_threshold=0.75)

Result

id dividend_per_share payment_date record_date stock_type_specified
0 0.18 2021-05-24 00:00:00+00:00 2021-05-10 00:00:00+00:00 quarterly
0 0.15 2020-07-12 00:00:00+00:00 2020-07-01 00:00:00+00:00 quarterly
1 0.25 2021-06-15 00:00:00+00:00 2021-06-01 00:00:00+00:00

Spot Checking

Use spotcheck() to check if results look good. Highly recommended to use a more powerful model for spot checking, and cheap model for dataset generation.

spotchecks = builder.spotcheck(schema=DividendExtraction, model="gemini-2.5-flash", entries=entries,
               results=results, sample_size=10, rpm=4_000, tpm=4_000_000, rpm_threshold=0.75, tpm_threshold=0.75)

Returns a per-field verdict for each sampled entry:

[
  {'id': 0, 'fields': [
    {'name': 'dividend_per_share', 'verdict': 'correct', 'desc': '$0.18 explicitly stated in source.'},
    {'name': 'stock_type_specified', 'verdict': 'fabricated', 'desc': "'quarterly' not stated for this dividend."}
  ]},
  {'id': 1, 'fields': [
    {'name': 'dividend_per_share', 'verdict': 'correct', 'desc': '$0.25 explicitly stated.'},
  ]}
]

Customize the spot check prompt and verdict types via config:

from txt2dataset import config

config.SET_SPOT_CHECK_PROMPT("""Here is a source document and some data extracted from it.

For each extracted row, check each field value against the source document.
Only flag a value as wrong if something is egregiously wrong — meaning
the extracted value cannot be found in or inferred from the source
text with some generosity.

null values are correct when the source does not mention that field — do not flag null as debatable or fabricated simply because the field is absent from the source.

Return JSON as a list of objects, one per extracted row, each with:
- id: the row_index of the extracted row
- fields: array of objects with:
  - name: field name
  - verdict: 'correct', 'fabricated', or 'debatable'
  - desc: brief explanation of why""")
config.SET_SPOT_CHECK_SCHEMA({
    "type": "array",
    "items": {
        "type": "object",
        "properties": {
            "id": {"type": "integer"},
            "fields": {
                "type": "array",
                "items": {
                    "type": "object",
                    "properties": {
                        "name": {"type": "string"},
                        "verdict": {"type": "string"},
                        "desc": {"type": "string"},
                    },
                    "required": ["name", "verdict", "desc"],
                },
            },
        },
        "required": ["id", "fields"],
    },
})
config.SET_SPOT_CHECK_VERDICT_COLORS({"correct": "#e8f5e9", "fabricated": "#ffebee", "slightly_off": "#fff8e1"})

Spot Checking Visualization

Use spotcheck_visualize() for an interactive visual method.

Hotkeys: LEFT/RIGHT (or A/D) to navigate, F to copy extracted rows (JSON) to clipboard, R to reject and append to reject.json, P to copy the current ID, O to reject and append to reject_id.json (configurable).

Customize hotkeys via txt2dataset.config (e.g. from txt2dataset import config; config.SET_REJECT_KEY("X")) before calling spotcheck_visualize(). Settings persist in ~/.txt2dataset/config.json (override with TXT2DATASET_CONFIG_PATH).

SET_* accepts a string or a list (to bind multiple keys). For BACK/FORWARD, include "ArrowLeft" / "ArrowRight" in the list if you want to keep arrow navigation.

Example:

from txt2dataset import config

config.SET_BACK_KEY(["ArrowLeft", "J"])
config.SET_FORWARD_KEY(["ArrowRight", "K"])
config.SET_COPY_EXTRACTED_ROWS_KEY(["F", "C"])
config.SET_COPY_ID_KEY(["P"])
config.SET_DOWNLOAD_EXTRACTED_ROWS_KEY(["O"])
config.SET_REJECT_KEY(["R", "X"])
config.SET_REJECT_FILE("my_rejects.json")
builder.spotcheck_visualize(schema=DividendExtraction, model="gemini-2.5-flash", entries=entries,
               results=results, sample_size=10, rpm=4_000, tpm=4_000_000, rpm_threshold=0.75, tpm_threshold=0.75)

spot check visualization

Examples

See examples.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

txt2dataset-0.6.3.tar.gz (24.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

txt2dataset-0.6.3-py3-none-any.whl (28.3 kB view details)

Uploaded Python 3

File details

Details for the file txt2dataset-0.6.3.tar.gz.

File metadata

  • Download URL: txt2dataset-0.6.3.tar.gz
  • Upload date:
  • Size: 24.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for txt2dataset-0.6.3.tar.gz
Algorithm Hash digest
SHA256 3d6c04d9afd7ffd69dcb47db7fc3a83156fea22f7d7a79b84e5420eaf7473bb4
MD5 2f8ad011b18b9ed9ea6c3dc59dc71db3
BLAKE2b-256 d1fae7aec7a82ec26e03e8dd927cd454afe5283fc7c7516aa7e9addcaf797873

See more details on using hashes here.

File details

Details for the file txt2dataset-0.6.3-py3-none-any.whl.

File metadata

  • Download URL: txt2dataset-0.6.3-py3-none-any.whl
  • Upload date:
  • Size: 28.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for txt2dataset-0.6.3-py3-none-any.whl
Algorithm Hash digest
SHA256 e64072c3b04d2d1b96a43b4c78885585c1072f1d80dccb7edc8e29b675dbc7a1
MD5 f4ab9d8f4b3c28fb60e61cd2a71560d4
BLAKE2b-256 9d0cf619f8ccd944b464e84ea4518e2772480f6aa55604d59fef49ddc1d644b9

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page