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"

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 = 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(prompt=prompt, 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)

Result

id correct desc
1 true
0 false The stock_type_specified for the $0.15 dividend is incorrectly listed as 'quarterly'; the source text does not explicitly state it for this particular dividend, so it should be null.

Spot Checking Visualization

Use spotcheck_visualize() for an interactive visual method.

builder.spotcheck_visualize(prompt=prompt, 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.

TODO

  • handle errors
  • spotcheck
  • standardize
  • store rate limits across multiple build commands

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.5.7.tar.gz (16.2 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.5.7-py3-none-any.whl (19.7 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for txt2dataset-0.5.7.tar.gz
Algorithm Hash digest
SHA256 2d9d67f5455de7d6cf2621479fb5fda425a75e6f898add3722a87d0ef119a773
MD5 6dff41b8589306ee5ffecf22967a1c6b
BLAKE2b-256 3d6628373e8f0625b154cfeb918f272f598328cd7c71bd793a1ff8bf80c1eee7

See more details on using hashes here.

File details

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

File metadata

  • Download URL: txt2dataset-0.5.7-py3-none-any.whl
  • Upload date:
  • Size: 19.7 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.5.7-py3-none-any.whl
Algorithm Hash digest
SHA256 832022afbf6b4c8b73fb40cada2714c6c3d5b6909fc348b8e52def52b11cbbc8
MD5 f3117bbd8981b1629d7516c8cc92cf3a
BLAKE2b-256 12e65ecce9b04d1a52aabec0b1a691875299d0e8d48d6de599f8b47f182a972a

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