Skip to main content

PydanticXML is a Python library that provides a way to convert Pydantic models to XML and vice versa.

Project description

PydanticXML

PydanticXML is a Python library that provides a way to convert Pydantic models to XML and vice versa. It is built on top of the Pydantic library and extends it with XML-specific functionality.

Features

  • Convert Pydantic models to XML and vice versa
  • Support for XML attributes, elements, content, lists.
  • Compatible with most Pydantic features (e.g. default values, validators, Field etc.)
  • Very easy to use. Extends Pydantic's API with only a few methods.
  • Has no dependencies other than Pydantic
  • Have a good docs in the source code
  • Fully tested

Installation

You can install PydanticXML with pip:

pip install pydantic-xmlmodel

Usage

To use PydanticXML, you need to import the XMLModel class from the pydanticxml module:

from pydantic_xmlmodel import XMLModel

Examples

Defining a Model

You can define a model by subclassing XMLModel and defining attributes with type annotations:

class AnimalCharacteristics(XMLModel):
    color: str = "black"
    weight: int = 10
    is_friendly: bool = True

Converting a Model to XML

You can convert a model to XML by calling the to_xml() method:

class Cat(XMLModel):
    animal_characteristics: AnimalCharacteristics
    name: str = "Kitty"

cat = Cat(animal_characteristics=AnimalCharacteristics())
print(cat.to_xml(indent=4))

This will output:

<?xml version="1.0" ?>
<cat name="Kitty">
    <animalcharacteristics color="black" weight="10" is_friendly="True"/>
</cat>

Converting XML to a Model

You can convert XML to a model by calling the from_xml() method:

xml = """<?xml version="1.0" ?>
<cat name="Kitty">
    <animalcharacteristics color="black" is_friendly="true" weight="10"/>
</cat>
"""
cat = Cat.from_xml(xml)
print(cat)

This will output:

animal_characteristics=AnimalCharacteristics(color='black', weight=10, is_friendly=True, xml_content=None) name='Kitty' xml_content='\n    '

(Note that the xml_content attribute is not part of the model. It is used to store the XML content, like this <element> xml_content <other_element /></element>)

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

pydantic_xmlmodel-0.3.tar.gz (5.6 kB view details)

Uploaded Source

Built Distribution

pydantic_xmlmodel-0.3-py3-none-any.whl (6.5 kB view details)

Uploaded Python 3

File details

Details for the file pydantic_xmlmodel-0.3.tar.gz.

File metadata

  • Download URL: pydantic_xmlmodel-0.3.tar.gz
  • Upload date:
  • Size: 5.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.0 CPython/3.11.3 Linux/6.3.4-201.fc38.x86_64

File hashes

Hashes for pydantic_xmlmodel-0.3.tar.gz
Algorithm Hash digest
SHA256 3811d7e4cf5743650aa22919eefc221d46da306fae9329b534b6a7531dbf46cf
MD5 92ca588f1e6a802c76bfcd2dcd4220a4
BLAKE2b-256 fe6aeca90084b24e4cf43863d01f005a8084d3eabd1422a0d6877af5f05aeea2

See more details on using hashes here.

File details

Details for the file pydantic_xmlmodel-0.3-py3-none-any.whl.

File metadata

  • Download URL: pydantic_xmlmodel-0.3-py3-none-any.whl
  • Upload date:
  • Size: 6.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.0 CPython/3.11.3 Linux/6.3.4-201.fc38.x86_64

File hashes

Hashes for pydantic_xmlmodel-0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 5743fab54bc8bf841be5a60a6655a76bd6574ebe0fd2bcd0e490e9167fbe9301
MD5 f8ea76f775f4efe84924180e6874f6f0
BLAKE2b-256 7f7355e31079c251363a4429a44ea191fc5f49eafd2fb0dc9e005c0083c6321a

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