User Field
Classes related to user-defined fields in ODF documents.
This module provides classes for managing user field declarations content within the document, “text:user-defined”, text:user-field-get”, “text:user-field-input”.
Classes:
| Name | Description |
|---|---|
UserDefined |
A user-defined field instance, “text:user-defined”. |
UserDefinedMixin |
Mixin class for classes containing user defined fields. |
UserFieldGet |
A getter for a user field value, “text:user-field-get”. |
UserFieldInput |
An input field for a user-defined field, “text:user-field-input”. |
UserDefined
Bases: ElementTyped
A user-defined field instance, “text:user-defined”.
This element is similar to ‘text:user-field-get’ but is often used in contexts like headers or footers. It can be initialized directly with a value or can pull its value from a corresponding user-defined metadata field in the document’s meta section.
Attributes:
| Name | Type | Description |
|---|---|---|
name |
str
|
The name of the user field. |
style |
str
|
The data style to apply for formatting. |
Methods:
| Name | Description |
|---|---|
__init__ |
Initializes the UserDefined element. |
Source code in odfdo/user_field.py
192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 | |
_properties
class-attribute
instance-attribute
_properties = (
PropDef("name", "text:name"),
PropDef("style", "style:data-style-name"),
)
_tag
class-attribute
instance-attribute
_tag = 'text:user-defined'
name
instance-attribute
name = name
style
instance-attribute
style = style
text
instance-attribute
text = text
__init__
__init__(
name: str = "",
value: Any = None,
value_type: str | None = None,
text: str | None = None,
style: str | None = None,
from_document: Document | None = None,
**kwargs: Any,
) -> None
Initializes the UserDefined element.
If a document is provided via from_document, the element will be
populated with the value of the meta user-defined field of the same
name from that document.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
name
|
str
|
The name of the user-defined field. |
''
|
value
|
Any
|
The value of the field. |
None
|
value_type
|
str | None
|
The ODF value type (e.g., ‘string’). |
None
|
text
|
str | None
|
The textual representation of the value. |
None
|
style
|
str | None
|
The data style name for formatting. |
None
|
from_document
|
Document | None
|
A document from which to load the field’s value from the meta section. |
None
|
Source code in odfdo/user_field.py
211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 | |
UserDefinedMixin
Bases: Element
Mixin class for classes containing user defined fields.
Used by the following classes
- “text:a”
- “text:h”
- “text:meta”
- “text:meta-field”
- “text:p”
- “text:ruby-base”
- “text:span”
and “office:text”, “office:spreadsheet”,”office:presentation” for compatibility with previous versions.
Methods:
| Name | Description |
|---|---|
get_user_defined |
Returns a single user-defined field declaration that matches the specified criteria. |
get_user_defined_list |
Returns all user-defined field declarations as a list. |
get_user_defined_value |
Returns the value of the specified user-defined field. |
Attributes:
| Name | Type | Description |
|---|---|---|
user_defined_list |
list[UserDefined]
|
Returns all user-defined field declarations as a list. |
Source code in odfdo/user_field.py
49 50 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 77 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 | |
user_defined_list
property
user_defined_list: list[UserDefined]
Returns all user-defined field declarations as a list.
Returns:
| Type | Description |
|---|---|
list[UserDefined]
|
list[UserDefined]: A list of all UserDefined instances that are descendants of this element. |
get_user_defined
get_user_defined(
name: str, position: int = 0
) -> UserDefined | None
Returns a single user-defined field declaration that matches the specified criteria.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
name
|
str
|
The name of the user-defined field to retrieve. |
required |
position
|
int
|
The 0-based index of the matching user-defined field to return. |
0
|
Returns:
| Type | Description |
|---|---|
UserDefined | None
|
UserDefined | None: A UserDefined instance, or None if no declaration matches the criteria. |
Source code in odfdo/user_field.py
87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 | |
get_user_defined_list
get_user_defined_list() -> list[UserDefined]
Returns all user-defined field declarations as a list.
Returns:
| Type | Description |
|---|---|
list[UserDefined]
|
list[UserDefined]: A list of all UserDefined instances that are descendants of this element. |
Source code in odfdo/user_field.py
65 66 67 68 69 70 71 72 73 74 75 76 | |
get_user_defined_value
get_user_defined_value(
name: str, value_type: str | None = None
) -> (
bool
| str
| int
| float
| Decimal
| datetime
| timedelta
| None
)
Returns the value of the specified user-defined field.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
name
|
str
|
The name of the user-defined field to retrieve its value. |
required |
value_type
|
str | None
|
The expected type of the user-defined field’s value. Can be ‘boolean’, ‘date’, ‘float’, ‘string’, ‘time’, or None for automatic type detection. |
None
|
Returns:
| Type | Description |
|---|---|
bool | str | int | float | Decimal | datetime | timedelta | None
|
bool | str | int | float | Decimal | datetime | timedelta | None: The value of the user-defined field, cast to the most appropriate Python type, or None if the user-defined field is not found. |
Source code in odfdo/user_field.py
104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 | |
UserFieldGet
Bases: ElementTyped
A getter for a user field value, “text:user-field-get”.
This element displays the current value of a user-defined field at a specific position in the document content.
Attributes:
| Name | Type | Description |
|---|---|---|
name |
str
|
The name of the user field to display. |
style |
str
|
The data style to apply for formatting the displayed value. |
Methods:
| Name | Description |
|---|---|
__init__ |
Initializes the UserFieldGet element. |
Source code in odfdo/user_field.py
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 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 | |
_properties
class-attribute
instance-attribute
_properties = (
PropDef("name", "text:name"),
PropDef("style", "style:data-style-name"),
)
_tag
class-attribute
instance-attribute
_tag = 'text:user-field-get'
name
instance-attribute
name = name
style
instance-attribute
style = style
text
instance-attribute
text = text
__init__
__init__(
name: str | None = None,
value: Any = None,
value_type: str | None = None,
text: str | None = None,
style: str | None = None,
**kwargs: Any,
) -> None
Initializes the UserFieldGet element.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
name
|
str | None
|
The name of the user field to get. |
None
|
value
|
Any
|
An initial value to display. |
None
|
value_type
|
str | None
|
The ODF value type. |
None
|
text
|
str | None
|
The textual representation to display. If
not provided, it’s generated from |
None
|
style
|
str | None
|
The data style name for formatting. |
None
|
Source code in odfdo/user_field.py
144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 | |
UserFieldInput
Bases: UserFieldGet
An input field for a user-defined field, “text:user-field-input”.
This element allows the user to interactively modify the value of a user-defined field within the document.
Source code in odfdo/user_field.py
179 180 181 182 183 184 185 186 | |
_tag
class-attribute
instance-attribute
_tag = 'text:user-field-input'