Skip to main content

A package for generating, validating, and utilizing Draft-7 JSON schemas with LangChain

Project description

Lang2Logic Python Package

Introduction

Lang2Logic: Generating python objects with natural language.

Overview

Lang2Logic is an innovative Python package designed for developers who need to translate natural language prompts into structured Python outputs. Utilizing advanced language processing algorithms, Lang2Logic simplifies generating Python code from verbal or written descriptions.

Key Features

  • Natural Language to Python Conversion: Converts natural language instructions into Python code, facilitating easier programming and automation.
  • Dynamic Schema Generation: Automatically generates schema from natural language inputs, providing structured outputs like lists, dictionaries, etc.
  • Flexible API Integration: User-friendly API for seamless integration with existing Python projects.

Installation and Usage

import os
from Lang2Logic.generator import Generator

# Initialize with API key
test_gen = Generator(os.environ.get("YOUR_API_KEY"))

# Generate schema from natural language
schema = test_gen.generate_schema("return a list of strings")

# The 'schema' here is an instance of the ResponseSchema class

Using the ResponseSchema Class

The ResponseSchema class is designed to handle and manipulate JSON schemas. It can accept a JSON string, a dictionary, or another instance of itself to create or modify a schema.

Creating an Instance

from Lang2Logic.response_schema import ResponseSchema

# Create a ResponseSchema instance from a dictionary
schema_dict = {"type": "object", "properties": {"name": {"type": "string"}}}
schema = ResponseSchema(schema_dict)

# Or from another ResponseSchema instance
another_schema = ResponseSchema(schema)

Getting Dictionary or JSON Representation

# Get the schema as a dictionary
schema_dict = schema.to_dict()

# Convert the schema to a JSON string
schema_json = schema.to_json()

Saving Schema to a File

# Save the schema to a JSON file
schema.save_to_json(key="mySchema", filepath="path/to/file.json")

Automatic Schema Generation

test_gen.generate("return a list of strings with 5 colors")
# The output is an instance of ResponseSchema
# Output: ["color1", "color2", "color3", "color4", "color5"]

Example Usage

Classifying Decisions and Preferences

schema = test_gen.generate_schema("return a dictionary with keys 'rational' and 'decision' (boolean)")

potential_buyers = []
for user in users_data_json["bios"]:
    decision = test_gen.generate(f"return true if this user might be interested in products related to rock climbing.\nUser Bio:\n{user['bio']}", schema)
    if decision["decision"]:
        potential_buyers.append(user)

Roadmap

  • Function Generation
  • Optimized Logic for Increased Accuracy
  • Code Parsing and LLM integration tools
  • Python Agents

Bug Reporting and Contributions

Found a bug or have a suggestion? Please contact dylanpwilson2005@gmail.com.

License

Lang2Logic is available under a Creative Commons license and may not be used for commercial purposes without explicit consent from the author.

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

Lang2Logic-1.1.6.tar.gz (16.6 kB view details)

Uploaded Source

Built Distribution

Lang2Logic-1.1.6-py3-none-any.whl (18.1 kB view details)

Uploaded Python 3

File details

Details for the file Lang2Logic-1.1.6.tar.gz.

File metadata

  • Download URL: Lang2Logic-1.1.6.tar.gz
  • Upload date:
  • Size: 16.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.10

File hashes

Hashes for Lang2Logic-1.1.6.tar.gz
Algorithm Hash digest
SHA256 a7ff142712f1a6f438ddd7ab384d114477bb89e02c128b25edca21463347db06
MD5 2fca376596a98ff5b695c757a811c6b2
BLAKE2b-256 97313b2d5587be44a341b499e40c5d97e638bbb15decd981619db27c46b7c536

See more details on using hashes here.

File details

Details for the file Lang2Logic-1.1.6-py3-none-any.whl.

File metadata

  • Download URL: Lang2Logic-1.1.6-py3-none-any.whl
  • Upload date:
  • Size: 18.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.10

File hashes

Hashes for Lang2Logic-1.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 7fd85066a1b833435442fc8ac83cc29ef2e9bb704bcf976fcb9617a00eacd2dc
MD5 7b92d9720114c4053bde82d979bbb9c5
BLAKE2b-256 e0ab3da3ded72a82fcbfcbca3bc8820be665228a7e9c81084cbdd8bcc4963586

See more details on using hashes here.

Supported by

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