QCIOModelBase
qcio.models.base_models.QCIOModelBase
¶
Base Model for all QCIO objects.
Attributes:
Name | Type | Description |
---|---|---|
version |
The version of the schema. |
|
extras |
dict[str, Any]
|
Additional information to bundle with the object. Use for schema development and scratch space. |
open
classmethod
¶
open(filepath: Union[Path, str]) -> Union[Self, list[Self]]
Instantiate an object from data saved to disk.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
filepath |
Union[Path, str]
|
The path to the object on disk. |
required |
Returns:
Type | Description |
---|---|
Union[Self, list[Self]]
|
The instantiated object or a list of objects if the file contains multiple |
Union[Self, list[Self]]
|
objects (e.g., a multi-structure xyz file). |
Example
my_obj = MyModel.open("path/to/file.json")
Source code in qcio/models/base_models.py
51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 |
|
save
¶
save(filepath: Union[Path, str], exclude_none: bool = True, exclude_unset: bool = True, indent: int = 4, **kwargs) -> None
Save an object to disk as json
, yaml
, or toml
. Objects such as Structure
and OptimizationResults
can additionally be saved as xyz
files.
Note
By default the object will be saved as a json
file. If the file extension
is .yaml
or .yml
, the object will be saved as a yaml
file. If the file
extension is .toml
, the object will be saved as a toml
file. If the file
extension is .xyz
, the object will be saved as an xyz
file (for objects
that support this format such as a Structure
or an OptimizationResults
which contains .trajectory: list[Structure]
).
Additionally, padding will be added to the file by default to make it more
human-readable. You can adjust the amount of padding added by changing the
indent
parameter. Pass indent=None
to create a more compact file.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
filepath |
Union[Path, str]
|
The path to write the object to. |
required |
exclude_none |
bool
|
If True, attributes with a value of None will not be written. Changing default behavior from pydantic.model_dump() to True. |
True
|
exclude_unset |
bool
|
If True, attributes that have not been set will not be written (i.e., values set to their default value). |
True
|
indent |
int
|
The number of spaces to use for indentation in the JSON file. 0 creates a more compact JSON file, 4 is more human-readable. |
4
|
**kwargs |
Additional keyword arguments to pass to the serialization method. |
{}
|
Example
my_obj.save("path/to/file.json")
my_obj.save("path/to/file.yaml")
my_obj.save("path/to/file.toml")
my_obj.save("path/to/file.xyz")
Source code in qcio/models/base_models.py
78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 |
|