.time
class: Time
- class Time(**kwargs)[source]
Time options that can apply globally or to individual charts. These settings affect how datetime axes are laid out, how tooltips are formatted, how series
point_interval_unit <Series.point_interval_unit()
works and how the Highcharts Stock range selector handles time.Class Inheritance
- copy(other=None, overwrite=True, **kwargs)
Copy the configuration settings from this instance to the
other
instance.- Parameters:
other (
HighchartsMeta
) – The target instance to which the properties of this instance should be copied. IfNone
, will create a new instance and populate it with properties copied fromself
. Defaults toNone
.overwrite (
bool
) – ifTrue
, properties inother
that are already set will be overwritten by their counterparts inself
. Defaults toTrue
.kwargs – Additional keyword arguments. Some special descendents of
HighchartsMeta
may have special implementations of this method which rely on additional keyword arguments.
- Returns:
A mutated version of
other
with new property values
- classmethod from_dict(as_dict: dict, allow_snake_case: bool = True)
Construct an instance of the class from a
dict
object.
- classmethod from_js_literal(as_str_or_file, allow_snake_case: bool = True, _break_loop_on_failure: bool = False)
Return a Python object representation of a Highcharts JavaScript object literal.
- Parameters:
as_str_or_file (
str
) – The JavaScript object literal, represented either as astr
or as a filename which contains the JS object literal.allow_snake_case (
bool
) – IfTrue
, interpretssnake_case
keys as equivalent tocamelCase
keys. Defaults toTrue
._break_loop_on_failure (
bool
) – IfTrue
, will break any looping operations in the event of a failure. Otherwise, will attempt to repair the failure. Defaults toFalse
.
- Returns:
A Python object representation of the Highcharts JavaScript object literal.
- Return type:
HighchartsMeta
- classmethod from_json(as_json_or_file, allow_snake_case: bool = True)
Construct an instance of the class from a JSON string.
- Parameters:
as_json_or_file – The JSON string for the object or the filename of a file that contains the JSON string.
allow_snake_case (
bool
) – IfTrue
, interpretssnake_case
keys as equivalent tocamelCase
keys. Defaults toTrue
.
- Returns:
A Python objcet representation of
as_json
.- Return type:
HighchartsMeta
- get_required_modules(include_extension=False) List[str]
Return the list of URLs from which the Highcharts JavaScript modules needed to render the chart can be retrieved.
- to_dict() dict
Generate a
dict
representation of the object compatible with the Highcharts JavaScript library.Note
The
dict
representation has a property structure and naming convention that is intentionally consistent with the Highcharts JavaScript library. This is not Pythonic, but it makes managing the interplay between the two languages much, much simpler.
- to_js_literal(filename=None, encoding='utf-8', careful_validation=False) str | None
Return the object represented as a
str
containing the JavaScript object literal.- Parameters:
along the way using the esprima-python library. Defaults to
False
.Warning
Setting this value to
True
will significantly degrade serialization performance, though it may prove useful for debugging purposes.
- to_json(filename=None, encoding='utf-8', for_export: bool = False)
Generate a JSON string/byte string representation of the object compatible with the Highcharts JavaScript library.
Note
This method will either return a standard
str
or abytes
object depending on the JSON serialization library you are using. For example, if your environment has orjson, the result will be abytes
representation of the string.- Parameters:
filename (Path-like) – The name of a file to which the JSON string should be persisted. Defaults to
None
encoding (
str
) – The character encoding to apply to the resulting object. Defaults to'utf-8'
.for_export (
bool
) – IfTrue
, indicates that the method is being run to produce a JSON for consumption by the export server. Defaults toFalse
.
- Returns:
A JSON representation of the object compatible with the Highcharts library.
- Return type:
- static trim_dict(untrimmed: dict, to_json: bool = False, context: str = None, for_export: bool = False) dict
Remove keys from
untrimmed
whose values areNone
and convert values that have.to_dict()
methods.- Parameters:
untrimmed (
dict
) – Thedict
whose values may still beNone
or Python objects.to_json (
bool
) – IfTrue
, will remove all keys fromuntrimmed
that are not serializable to JSON. Defaults toFalse
.context (
str
orNone
) – If provided, will inform the method of the context in which it is being run which may inform special handling cases (e.g. where empty strings may be important / allowable). Defaults toNone
.for_export (
bool
) – IfTrue
, indicates that the method is being run to produce a JSON for consumption by the export server. Defaults toFalse
.
- Returns:
Trimmed
dict
- Return type:
- static trim_iterable(untrimmed, to_json=False, context: str = None, for_export: bool = False)
Convert any
EnforcedNullType
values inuntrimmed
to'null'
.- Parameters:
untrimmed (iterable) – The iterable whose members may still be
None
or Python objects.to_json (
bool
) – IfTrue
, will remove all members fromuntrimmed
that are not serializable to JSON. Defaults toFalse
.context (
str
orNone
) – If provided, will inform the method of the context in which it is being run which may inform special handling cases (e.g. where empty strings may be important / allowable). Defaults toNone
.for_export (
bool
) – IfTrue
, indicates that the method is being run to produce a JSON for consumption by the export server. Defaults toFalse
.
- Return type:
iterable
- property Date: JavaScriptClass | None
A custom JavaScript
Date
class for more sophisticated date handling. For example, JDate can be used to handle Jalali dates. Defaults toNone
.- Return type:
JavaScriptClass
orNone
- property get_timezone_offset: CallbackFunction | None
A JavaScript callback function that returns the time zone offset for a given datetime. Defaults to
None
.The function is expected to take a Unix timestamp (as number of milliseconds since January 1, 1970) as an argument and return the timezone offset in minutes.
Hint
This provides a hook for drawing time based charts in specific time zones using their local DST crossover dates, with the help of external libraries.
Warning
If
Time.timezone()
is specified, then this custom function will be overridden by an automatic function leveraging the moment.js library.- Return type:
CallbackFunction
orNone
- property moment: CallbackFunction | None
A JavaScript function that can be used to manually load the moment.js library when initializing a chart, rather than loading it from within
window
or a<script/>
tag. Defaults toNone
.Note
The function expects no arguments and returns no result.
Warning
If loading
moment.js
is loaded from within a<script/>
tag on the page, this setting can be left asNone
. Highcharts will still be able to access and use the library.- Return type:
CallbackFunction
orNone
- property timezone: str | None
Indicates the timezone in which to render the chart. Defaults to
None
.If this value is provided, Highcharts will override the setting for
Time.get_timezone_offset()
with a default function leveraging the moment.js library.Warning
Requires moment.js to work properly. If
moment.js
is not available, this will throw a Highcharts error in the JavaScript console but will not prevent the chart from rendering.
- property timezone_offset: int | None
The timezone offset to apply in minutes. Defaults to
0
.Hint
Use this to display UTC data in a predefined timezone.
Note
Positive values are west of UTC. Negative values are east of UTC, as in the ECMAScript getTimezoneOffset() method.
- property use_utc: bool | None
If
True
, use UTC time for axis scaling, tickmark placement, and time display. Defaults toTrue
.Hint
The advantage of using UTC is that the time displays equally regardless of the user agent’s time zone settings. Local time can be used when the data is loaded in real time or when correct Daylight Saving Time transitions are required.