.map_data
class: MapData
- class MapData(**kwargs)[source]
The map geometry data which defines the areas and features of the map itself.
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)[source]
Construct an instance of the class from a
dict
object.
- classmethod from_geodataframe(as_gdf, prequantize=False, **kwargs)[source]
Create a
MapData
instance from ageopandas.GeoDataFrame
.- Parameters:
as_gdf (
geopandas.GeoDataFrame
) – Thegeopandas.GeoDataFrame
containing the map geometry.prequantize (
bool
) – IfTrue
, will perform the TopoJSON optimizations (“quantizing the topology”) before generating theTopology
instance. Defaults toFalse
.kwargs (
dict
) – additional keyword arguments which are passed to theTopology
constructor
- Return type:
- classmethod from_geojson(as_geojson_or_file: str | bytes, allow_snake_case: bool = True)[source]
Construct an instance of the class from a JSON string.
- Parameters:
- Returns:
A Python objcet representation of
as_geojson_or_file
.- Return type:
- 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: str | bytes, allow_snake_case: bool = True)[source]
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:
- classmethod from_shapefile(shp_filename)[source]
Create a
MapData
instance from an ESRI Shapefile.- Parameters:
The full filename of an ESRI Shapefile to load.
Note
ESRI Shapefiles are actually composed of three files each, with one file receiving the
.shp
extension, one with a.dbf
extension, and one (optional) file with a.shx
extension.Highcharts Maps for Python will resolve all three files given a single base filename. Thus:
/my-shapefiles-folder/my_shapefile.shp
will successfully load data from the three files:
/my-shapefiles-folder/my_shapefile.shp
/my-shapefiles-folder/my_shapefile.dbf
/my-shapefiles-folder/my_shapefile.shx
Tip
Highcharts for Python will also correctly load and unpack shapefiles that are grouped together within a ZIP file.
- Return type:
- classmethod from_topojson(as_topojson_or_file: str | bytes, allow_snake_case: bool = True)[source]
Construct an instance of the class from a TopoJSON string.
- Parameters:
- Returns:
A Python objcet representation of
as_topojson_or_file
.- Return type:
- 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_geodataframe(object_name=None)[source]
Generate a
geopandas.GeoDataFrame
instance of the map geometry.
- to_geojson(filename=None, encoding='utf-8')[source]
Generate a GeoJSON string/byte string representation of the object.
- to_js_literal(filename=None, encoding='utf-8') str | None [source]
Return the object represented as a
str
containing the JavaScript object literal.
- to_json(filename=None, encoding='utf-8')[source]
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:
- Returns:
A JSON representation of the object compatible with the Highcharts library.
- Return type:
- to_topojson(filename=None, encoding='utf-8')[source]
Generate a TopoJSON string/byte string representation of the object.
- static trim_dict(untrimmed: dict, to_json: bool = False) dict
Remove keys from
untrimmed
whose values areNone
and convert values that have.to_dict()
methods.
- static trim_iterable(untrimmed, to_json=False)
Convert any
EnforcedNullType
values inuntrimmed
to'null'
.
class: AsyncMapData
- class AsyncMapData(**kwargs)[source]
Configuration of map geometry which Highcharts Maps should fetch asynchronously using client-side JavaScript.
Note
When serialized to a JS literal will execute an async (JavaScript)
fetch()
call to download the map data from.url
.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
- 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') str | None [source]
Return the object represented as a
str
containing the JavaScript object literal.
- to_json(filename=None, encoding='utf-8')
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:
- Returns:
A JSON representation of the object compatible with the Highcharts library.
- Return type:
- static trim_dict(untrimmed: dict, to_json: bool = False) dict
Remove keys from
untrimmed
whose values areNone
and convert values that have.to_dict()
methods.
- static trim_iterable(untrimmed, to_json=False)
Convert any
EnforcedNullType
values inuntrimmed
to'null'
.
- property fetch_config: FetchConfiguration | None
Optional configuration settings to use when executing the (JavaScript) asynchronous
fetch()
call to download the map geometry. Defaults toNone
.Note
The
.url
. setting will override any URL set in theFetchConfiguration
.- Return type:
- property fetch_counter: int
The number to append to the
topology
variable name when serializing the map data. Defaults to0
.- Return type:
- property selector: CallbackFunction | None
An optional (JavaScript) function which receives the map geometry downloaded from
.url
, can perform some (arbitrary - it’s up to you!) operation on that data, and returns a new set of map geometries which will be visualized by Highcharts for Maps. Defaults toNone
.Note
The
selector
function must accept a single argument:topology
and must return a single value (which will be assigned to the JavaScript variable namedtopology
).- Return type: