Skip to main content

Type-guided parsing library for converting strings to Python objects

Project description

strto

Tests PyPI version Supported versions Downloads license

strto is a Python library for parsing strings into Python objects based on types and type annotations.

Installation

From PyPi

pip install strto

From source

pip install git+https://github.com/zigai/strto.git

Examples

>>> from strto import get_parser
>>> parser = get_parser()

>>> parser.parse("5", int)
5
>>> parser.parse("1.5", int | float)
1.5
>>> parser.parse("1,2,3,4,5", list[int])
[1, 2, 3, 4, 5]
>>> parser.parse('{"a":1,"b":2,"c":3}', dict[str, int])
{'a': 1, 'b': 2, 'c': 3}

import datetime
>>> parser.parse("2022.07.19", datetime.date)
datetime.date(2022, 7, 19)

>>> parser.parse("0:5:1", range)
range(0, 5, 1)

>>> import enum
>>> class Color(enum.Enum):
...     RED = 1
...     GREEN = 2
...     BLUE = 3
>>> parser.parse("RED", Color)
Color.RED

Automatic model parsing (dataclasses and pydantic v2)

strto can parse dataclasses and pydantic v2 models from JSON, files, or key/value strings:

from dataclasses import dataclass
from strto import get_parser

@dataclass
class NetworkAddress:
    host: str
    port: int

parser = get_parser()

parser.parse('{"host":"localhost","port":5432}', NetworkAddress)
parser.parse("host=localhost port=5432", NetworkAddress)
parser.parse("@addr.yaml", NetworkAddress)

Nested models via dotted keys (or nested JSON):

from dataclasses import dataclass

@dataclass
class NetworkAddress:
    host: str
    port: int

@dataclass
class ApplicationConfig:
    debug: bool = False
    network: NetworkAddress | None = None

parser.parse(
    "debug=true network.host=db network.port=5433",
    ApplicationConfig,
)

Notes:

  • Key/value parsing supports dotted keys for nested objects.
  • Use JSON arrays/objects for complex values (e.g., lists of objects).
  • Pydantic support requires pydantic v2 to be installed.

Optional: enable parsing for any class by inspecting __init__ with objinspect:

from strto import get_parser

parser = get_parser(allow_class_init=True)

Custom parser for alternative string formats

If you want a non-standard string format (e.g., host:port), register a custom parser to override the default model parsing for that type.

from dataclasses import dataclass
from strto import ParserBase, get_parser

@dataclass
class NetworkAddress:
    host: str
    port: int

class NetworkAddressParser(ParserBase):
    def parse(self, value: str) -> NetworkAddress:
        host, port = value.rsplit(":")
        return NetworkAddress(host=host, port=int(port))

parser = get_parser()
parser.add(NetworkAddress, NetworkAddressParser())
result = parser.parse("example.com:8080", NetworkAddress)
print(result)  # NetworkAddress(host='example.com', port=8080)

# You can also use a function
def parse_network_address(value: str) -> NetworkAddress:
    host, port = value.rsplit(":")
    return NetworkAddress(host=host, port=int(port))

parser = get_parser()
parser.add(NetworkAddress, parse_network_address)
result = parser.parse("example.com:8080", NetworkAddress)
print(result)  # NetworkAddress(host='example.com', port=8080)

License

MIT License

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

strto-0.2.8.tar.gz (84.5 kB view details)

Uploaded Source

Built Distribution

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

strto-0.2.8-py3-none-any.whl (15.3 kB view details)

Uploaded Python 3

File details

Details for the file strto-0.2.8.tar.gz.

File metadata

  • Download URL: strto-0.2.8.tar.gz
  • Upload date:
  • Size: 84.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for strto-0.2.8.tar.gz
Algorithm Hash digest
SHA256 152e94f55c9f485f72720d05c240b218e160f452055e0aebe1c15b2a013769b2
MD5 7bc687d5bc319fac70b8ef6193527d75
BLAKE2b-256 83fb7ce76b55983668cae2af977043a994de1da0ed1bcc1fc2cacd093589db0a

See more details on using hashes here.

File details

Details for the file strto-0.2.8-py3-none-any.whl.

File metadata

  • Download URL: strto-0.2.8-py3-none-any.whl
  • Upload date:
  • Size: 15.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for strto-0.2.8-py3-none-any.whl
Algorithm Hash digest
SHA256 8764fb4c1dc4db51a471cf159ae6d9a8b77f3a2951a3483a24105d63825be6aa
MD5 a1343b803f903362c7835420efd7e5d5
BLAKE2b-256 1ca7be8d8c1f322487673a58f04f046a89bf0c3feebb4a5d994d6ad091ed87d5

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