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.1.tar.gz (5.6 kB view details)

Uploaded Source

Built Distribution

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

Uploaded Python 3

File details

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

File metadata

  • Download URL: pydantic_xmlmodel-0.3.1.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.1.tar.gz
Algorithm Hash digest
SHA256 b28200353bcfc7a20b3c2b701f1f7fb3a935f59017b70f58c569f0fa1ae46843
MD5 bdf1644507df2639f32f4f1e9bed15af
BLAKE2b-256 a02f47c08b38c9a8332e86de9d100c399a7ffc3a0bd3ab138f8c7e8cb09eece5

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pydantic_xmlmodel-0.3.1-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.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b0445056fd7bc81ed131c251777d0254da2cee2f3bb13beb04d467c6f93f28cc
MD5 40362d0c14f3fce9146cf96d9f12c1a5
BLAKE2b-256 c96cfa89f1e90a6be3756205ce1e5b7990d32c7fbc59fb49acd754dfa64f0100

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