Generates XML documents from XSD schemas
Project description
XML Generator
Generates XML documents based on XSD schemas with the ability to customize data through a YAML configuration file.
Simplifies the creation of test or demonstration XML data for complex schemas.
Features
- Generation of XML documents based on XSD schemas
- Customization of generated values via a YAML configuration file
- Validation of generated documents
- Command-line interface for convenient use
Installation
Installation via pip
pip install xmlgenerator
Install executable file manually (linux)
curl -LO https://github.com/lexakimov/xmlgenerator/releases/latest/download/xmlgenerator-linux-amd64
chmod +x xmlgenerator-linux-amd64
sudo install xmlgenerator-linux-amd64 /usr/local/bin/xmlgenerator
# also, you can install shell completions
# available: bash, zsh, tcsh
xmlgenerator -C bash | sudo tee /etc/bash_completion.d/xmlgenerator
Usage
The generator command is xmlgenerator
Flags and parameters:
usage: xmlgenerator [-h] [-c <config.yml>] [-o <output.xml>] [-p] [-n alias=namespace] [-v <validation>] [-ff]
[-e <encoding>] [-s <seed>] [-d] [-V] [-C <shell>]
xsd [xsd ...]
Generates XML documents from XSD schemas
positional arguments:
xsd paths to xsd schema(s) or directory with xsd schemas
options:
-h, --help show this help message and exit
-c, --config <config.yml> pass a YAML configuration file
-o, --output <output.xml> save the output to a directory or file
-p, --pretty prettify the output XML
-n, --namespace alias=namespace define XML namespace alias (repeatable flag)
-v, --validation <validation> validate the generated XML document (none, schema, schematron; default: schema)
-i continue execution when validation errors occur
-e, --encoding <encoding> the output XML encoding (utf-8, windows-1251; default: utf-8)
-s, --seed <seed> set the randomization seed
-d, --debug enable debug mode
-V, --version show the current version
-C, --completion <shell> print a shell completion script (bash, zsh, tcsh)
Examples:
-
Generate XML from a single schema and print to console:
xmlgenerator path/to/your/schema.xsd -
Generate XML from all schemas in a directory and save to the
outputfolder using a configuration file:xmlgenerator -c config.yml -o output/ path/to/schemas/
-
Generate XML from a specific schema, save to a file with pretty formatting and windows-1251 encoding:
xmlgenerator -o output.xml -p -e windows-1251 path/to/your/schema.xsd
-
Generate XML with validation disabled:
xmlgenerator -v none path/to/your/schema.xsd
Configuration
The generator can be configured using a YAML file passed via the -c or --config option.
Description and examples of configuration are in CONFIGURATION.
Validation
Generated XML documents are checked for conformance against the schema used for generation. By default, validation against the source XSD schema is used.
If a document does not conform to the schema, execution stops immediately.
To keep processing despite validation errors, pass the -i flag.
To disable validation, use the flag -v none or --validation none.
Contribution
Contributions are welcome! Please open an issue or submit a pull request on GitHub.
Build from source
-
Clone the repository:
git clone https://github.com/lexakimov/xmlgenerator.git cd xmlgenerator
-
Create and activate a virtual environment (recommended):
python -m venv .venv
- For Linux/macOS:
source .venv/bin/activate
- For Windows (Command Prompt/PowerShell):
.\.venv\Scripts\activate
- For Linux/macOS:
-
Install dependencies:
pip install -r requirements.txt
4.1. Install the package:
Install in develop mode (code changes will be immediately reflected):
pip install -e .
4.2. Otherwise, build single executable:
python build_native.py
Running Tests
pytest
License
This project is licensed under the MIT License. See the LICENSE file for details.
Contacts
For any questions or issues, please contact [lex.akimov23@gmail.com].
You can also create an Issue on GitHub to report bugs or suggest improvements.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file xmlgenerator-0.8.1.tar.gz.
File metadata
- Download URL: xmlgenerator-0.8.1.tar.gz
- Upload date:
- Size: 20.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7bb5b6cf41f719e2d42b927541df88480f2bf3b8082498b10a597e3553daa356
|
|
| MD5 |
c6ba5fc1077b37ce6cb900636194a2cc
|
|
| BLAKE2b-256 |
289f359f0ca0b5728ecbb1fdd26f45da45147ba5d7d3fec58cd39eb5cbe119a2
|
File details
Details for the file xmlgenerator-0.8.1-py3-none-any.whl.
File metadata
- Download URL: xmlgenerator-0.8.1-py3-none-any.whl
- Upload date:
- Size: 20.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b6c5a60f5055870efa29ab5bbd4037b22654ddc243f4491f4bb9afeb004573f6
|
|
| MD5 |
b7c0c4f70982adcfada91240c6a062ab
|
|
| BLAKE2b-256 |
d1be2e13c1a7a2066f74411124de431a1fd2284349a5d30ca235cf1165cf7c5a
|