Welcome to graphql2python’s documentation!#
graphql2python is a tool that generates python code out of your GraphQL schema. If you are using python as GraphQL client you can to generate pydantic data-model with graphql2python.
GraphQL query generation moved to https://github.com/denisart/graphql-query
Documentation for version: 0.0.6
Contents#
Quickstart#
Install with pip
pip install graphql2python
Create the following file
# graphql2python.yaml schema: ./schema.graphql output: ./model.py
and run the following command
graphql2python render --config ./graphql2python.yaml
See the documentation for all the possibilities ( while it is docs/source/).
Config reference#
Global keywords
keyword | description |
schema | A path to the target GraphQL schema file. |
output | A file name for output py file. |
license_file | An optional path to a file with license for output py file. |
options | Optional options for render of output py file. |
Options keywords
keywords | description |
max_line_len | The maximum of line length of output py file. Default is 120. |
name_suffix | A suffix for invalid field name (as python object name). Default is “_”. |
each_field_optional | Each fields of interfaces and objects are optional. Default is false. |
add_from_dict | Add from_dict (dict -> model) method to the general class. Default is false. |
add_to_dict | Add to_dict (model -> dict) method to the general class. Default is false. |
scalar_pytypes | A dict with python types for custom GraphQL scalars. Maps from scalar name to python type name. Default is empty dict. |
fields_setting | Settings for interfaces or objects fields. Maps from object name to a dict with setting. Default is empty dict. |
fields_setting keywords for some object name
keywords | description |
alias | An alias for a field (see Field.alias for pydantic). Default is null. |
new_name | A new name for a field. Default is null. |
An example for graphql2python.yaml config:
# graphql2python.yaml schema: ./schema/schema.graphql output: ./model/model.py license_file: ./LICENSE options: scalar_pytypes: String: str Float: float Int: int ID: str Boolean: bool DateTime: datetime Date: date max_line_len: 79 each_field_optional: true fields_setting: MyObjectName: from: alias: from new_name: correct_from