Source code for databench.utils

"""Utility functions."""

import base64
import io
import json

    import numpy as np
except ImportError:
    np = None

[docs]def json_encoder_default(obj): """Handle more data types than the default JSON encoder. Specifically, it treats a `set` and a `numpy.array` like a `list`. Example usage: ``json.dumps(obj, default=json_encoder_default)`` """ if np is not None and hasattr(obj, 'size') and hasattr(obj, 'dtype'): if obj.size == 1: if np.issubdtype(obj.dtype, np.integer): return int(obj) elif np.issubdtype(obj.dtype, np.floating): return float(obj) if isinstance(obj, set): return list(obj) elif hasattr(obj, 'to_native'): # DatastoreList, DatastoreDict return obj.to_native() elif hasattr(obj, 'tolist') and hasattr(obj, '__iter__'): # for np.array return obj.tolist() return obj
[docs]def fig_to_src(figure, image_format='png', dpi=80): """Convert a matplotlib figure to an inline HTML image. :param matplotlib.figure.Figure figure: Figure to display. :param str image_format: png (default) or svg :param int dpi: dots-per-inch for raster graphics. :rtype: str """ if image_format == 'png': f = io.BytesIO() figure.savefig(f, format=image_format, dpi=dpi) return png_to_src( elif image_format == 'svg': f = io.StringIO() figure.savefig(f, format=image_format, dpi=dpi) return svg_to_src(
[docs]def png_to_src(png): """Convert a PNG string to a format that can be passed into a src. :rtype: str """ return 'data:image/png;base64,' + base64.b64encode(png).decode()
[docs]def svg_to_src(svg): """Convert an SVG string to a format that can be passed into a src. :rtype: str """ return 'data:image/svg+xml;utf8,' + svg
def to_string(*args, **kwargs): if len(args) == 1 and not kwargs and isinstance(args[0], str): message = args[0] elif not kwargs: message = json.dumps(args) elif not args: message = json.dumps(kwargs) else: message = json.dumps(args) + ', ' + json.dumps(kwargs) return message