highcharts-core


Namehighcharts-core JSON
Version 1.7.0 PyPI version JSON
download
home_pageNone
SummaryHigh-end Data Visualization for the Python Ecosystem. Official wrapper for Highcharts Core (JS).
upload_time2024-04-07 18:26:48
maintainerNone
docs_urlNone
authorNone
requires_python>=3.10
licenseNone
keywords charts data visualization data viz graphing highcharts highcharts js plotting
VCS
bugtrack_url
requirements esprima requests validator-collection
Travis-CI
coveralls test coverage No coveralls.
            ###################################################
Highcharts Core for Python
###################################################

**High-end data visualization for the Python ecosystem**

**Highcharts Core for Python** is a Python library that provides a Python wrapper
for the `Highcharts Core <https://www.highcharts.com/products/highcharts/>`__ JavaScript data
visualization library, with full integration into the robust Python ecosystem, including: 

  * **Jupyter Labs/Notebook**. You can now produce high-end and interactive plots and
    renders using the full suite of Highcharts visualization capabilities.
  * **Pandas**. Automatically produce data visualizations from your Pandas dataframes
  * **PySpark**. Automatically produce data visualizations from data in a PySpark
    dataframe.
  * ...and even more use-case specific integrations across the broader toolkit.

The library supports Highcharts (JS) v.10.2 and higher, including Highcharts (JS) v.11.4.0.

**COMPLETE DOCUMENTATION:** https://core-docs.highchartspython.com/en/latest/index.html

-------------

***************************************
The Highcharts for Python Toolkit
***************************************

The **Highcharts Core for Python** library is - as the name suggests - the core library in 
the broader `Highcharts for Python Toolkit <https://www.highcharts.com/integrations/python>`__, 
which together provides comprehensive support across the entire 
`Highcharts <https://www.highcharts.com>`__ suite of data visualization libraries:

.. list-table::
  :widths: 30 30 40
  :header-rows: 1

  * - Python Library
    - JavaScript Library
    - Description
  * - **Highcharts Core for Python** 
    - `Highcharts Core (JS) <https://www.highcharts.com/products/highcharts/>`__
    - (this library) the core Highcharts data visualization library
  * - `Highcharts Stock for Python <https://stock-docs.highchartspython.com/>`__ 
    - `Highcharts Stock (JS) <https://www.highcharts.com/products/stock/>`__
    - the time series visualization extension to Highcharts Core
  * - `Highcharts Maps for Python <https://maps-docs.highchartspython.com/>`__ 
    - `Highcharts Maps (JS) <https://www.highcharts.com/products/maps/>`__
    - the map visualization extension to Highcharts Core
  * - `Highcharts Gantt for Python <https://gantt-docs.highchartspython.com/>`__
    - `Highcharts Gantt (JS) <https://www.highcharts.com/products/gantt/>`__
    - the Gantt charting extension to Highcharts Core
  * - (all libraries in the Python toolkit)
    - The **Highcharts Export Server** 
    - enabling the programmatic creation of static (downloadable) data visualizations

--------------------

***************
Installation
***************

To install **Highcharts Core for Python**, just execute:

.. code:: bash

 $ pip install highcharts-core

Before you install, please be aware of the following "hard" dependencies:

  * Python 3.10 or higher
  * Highcharts Core (JS) v.10.2 or higher (not technically a Python dependency, but 
    it won't work with earlier versions of Highcharts)
  * `esprima-python <https://github.com/Kronuz/esprima-python>`__ v.4.0 or higher
  * `requests <https://requests.readthedocs.io/en/latest/>`__ v.2.31 or higher
  * `validator-collection <https://validator-collection.readthedocs.io/en/latest/>`__
    v.1.5 or higher

You can find more information about soft and development dependencies in the
`complete documentation <https://core-docs.highchartspython.com/en/latest/#dependencies>`__.

-------------

************************************
Why Highcharts for Python?
************************************

`Highcharts <https://www.highcharts.com>`__ is the world's most popular, most powerful, 
category-defining JavaScript data visualization library. If you are building a web or 
mobile app/dashboard that will be visualizing data in some fashion, you should 
absolutely take a look at the Highcharts suite of solutions. Take a peak at some 
fantastic `demo visualizations <https://www.highcharts.com/demo>`__.

As a suite of JavaScript libraries, `Highcharts <https://www.highcharts.com>`__ is 
written in JavaScript, and is used to configure and render data visualizations in a
web browser (or other JavaScript-executing) environment. As a set of JavaScript
libraries, its audience is JavaScript developers. But what about the broader ecosystem of
Python developers and data scientists?

Given Python's increasing adoption as the technology of choice for data science and for
the backends of leading enterprise-grade applications, Python is often the backend that 
delivers data and content to the front-end...which then renders it using JavaScript and 
HTML.

There are numerous Python frameworks (Django, Flask, Tornado, etc.) with specific
capabilities to simplify integration with Javascript frontend frameworks (React, Angular,
VueJS, etc.). But facilitating that with Highcharts has historically been very difficult.
Part of this difficulty is because the Highcharts JavaScript suite - while supporting JSON as a
serialization/deserialization format - leverages JavaScript object literals to expose the
full power and interactivity of its data visualizations. And while it's easy to serialize
JSON from Python, serializing and deserializing to/from JavaScript object literal notation
is much more complicated. 

This means that Python developers looking to integrate with Highcharts typically had to 
either invest a lot of effort, or were only able to leverage a small portion of Highcharts' 
rich functionality.

So we wrote the **Highcharts for Python** toolkit to bridge that gap.

**Highcharts for Python** provides Python object representation for *all* of the
JavaScript objects defined in the
`Highcharts (JavaScript) API <https://api.highcharts.com/highcharts/>`__. It provides automatic 
data validation, and exposes simple and standardized methods for serializing those Python
objects back-and-forth to JavaScript object literal notation.


Key Highcharts Core for Python Features
===========================================

* **Clean and consistent API**. No reliance on "hacky" code, ``dict``
  and JSON serialization, or impossible to maintain / copy-pasted "spaghetti code".
* **Comprehensive Highcharts Support**. Every single Highcharts chart type and every
  single configuration option is supported in the **Highcharts for Python** toolkit.
  Highcharts Core for Python includes support for the over 70 data visualization types 
  supported by `Highcharts Core <https://www.highcharts.com/product/highcharts/>`__ and 
  while other libraries in the toolkit support the 50+ technical indicator visualizations 
  available in `Highcharts Stock <https://www.highcharts.com/product/stock/>`__. 
  
  Every Highcharts for Python library provides full support for the rich JavaScript 
  formatter (JS callback functions) capabilities that are often needed to get the most 
  out of Highcharts' visualization and interaction capabilities.

  .. note:: 
    
    **See Also**

    * `Supported Visualizations <https://core-docs.highchartspython.com/en/latest/visualizations.html>`__

* **Simple JavaScript Code Generation**. With one method call, produce production-ready
  JavaScript code to render your interactive visualizations using Highcharts' rich
  capabilities.
* **Easy and Robust Chart Download**. With one method call, produce high-end static
  visualizations that can be downloaded or shared as files with your audience. Produce
  static charts using the Highsoft-provided **Highcharts Export Server**, or using your 
  own private export server as needed.
* **Integration with Pandas and PySpark**. With two lines of code, produce a high-end
  interactive visualization of your Pandas or PySpark dataframe.
* **Consistent code style**. For Python developers, switching between Pythonic code
  conventions and JavaScript code conventions can be...annoying. So
  the Highcharts for Python toolkit applies Pythonic syntax with automatic conversion between
  Pythonic ``snake_case`` notation and JavaScript ``camelCase`` styles.

|

**Highcharts for Python** vs Alternatives
==============================================

For a discussion of **Highcharts for Python** in comparison to alternatives, please see
the **COMPLETE DOCUMENTATION:** https://core-docs.highchartspython.com/en/latest/index.html

---------------------

********************************
Hello World, and Basic Usage
********************************

1. Import Highcharts Core for Python
==========================================

.. code-block:: python
  
  # PRECISE-LOCATION PATTERN: BEST PRACTICE!
  # This method of importing Highcharts for Python objects yields the fastest
  # performance for the import statement. However, it is more verbose and requires
  # you to navigate the extensive Highcharts Core for Python API.

  # Import classes using precise module indications. For example:
  from highcharts_core.chart import Chart
  from highcharts_core.global_options.shared_options import SharedOptions
  from highcharts_core.options import HighchartsOptions
  from highcharts_core.options.plot_options.bar import BarOptions
  from highcharts_core.options.series.bar import BarSeries

  # CATCH-ALL PATTERN
  # This method of importing Highcharts for Python classes has relatively slow
  # performance because it imports hundreds of different classes from across the entire
  # library. This performance impact may be acceptable to you in your use-case, but
  # do use at your own risk.

  # Import objects from the catch-all ".highcharts" module.
  from highcharts_core import highcharts

  # You can now access specific classes without individual import statements.
  highcharts.Chart
  highcharts.SharedOptions
  highcharts.HighchartsOptions
  highcharts.BarOptions
  highcharts.BarSeries


2. Create Your Chart
================================

  .. code-block:: python

    # from a primitive array, using keyword arguments
    my_chart = Chart(data = [[1, 23], [2, 34], [3, 45]], 
                     series_type = 'line')

    # from a primitive array, using the .from_array() method
    my_chart = Chart.from_array([[1, 23], [2, 34], [3, 45]], 
                                series_type = 'line')

    # from a Numpy ndarray, using keyword arguments
    my_chart = Chart(data = numpy_array, series_type = 'line')

    # from a Numpy ndarray, using the .from_array() method
    my_chart = Chart.from_array(data = numpy_array, series_type = 'line')

    # from a JavaScript file
    my_chart = Chart.from_js_literal('my_js_literal.js')

    # from a JSON file
    my_chart = Chart.from_json('my_json.json')

    # from a Python dict
    my_chart = Chart.from_dict(my_dict_obj)

    # from a Pandas dataframe
    my_chart = Chart.from_pandas(df)

    # from a PySpark dataframe
    my_chart = Chart.from_pyspark(df,
                                  property_map = {
                                      'x': 'transactionDate',
                                      'y': 'invoiceAmt',
                                      'id': 'id'
                                  },
                                  series_type = 'line')

    # from a CSV
    my_chart = Chart.from_csv('/some_file_location/filename.csv')

    # from a HighchartsOptions configuration object
    my_chart = Chart.from_options(my_options)

    # from a Series configuration, using keyword arguments
    my_chart = Chart(series = my_series)

    # from a Series configuration, using .from_series()
    my_chart = Chart.from_series(my_series)
    
3. Configure Global Settings (optional)
=============================================

  .. code-block:: python

    # Import SharedOptions
    from highcharts_core.global_options.shared_options import SharedOptions

    # from a JavaScript file
    my_global_settings = SharedOptions.from_js_literal('my_js_literal.js')

    # from a JSON file
    my_global_settings = SharedOptions.from_json('my_json.json')

    # from a Python dict
    my_global_settings = SharedOptions.from_dict(my_dict_obj)

    # from a HighchartsOptions configuration object
    my_global_settings = SharedOptions.from_options(my_options)


4. Configure Your Chart / Global Settings
================================================

  .. code-block:: python

    from highcharts_core.options.title import Title
    from highcharts_core.options.credits import Credits

    # EXAMPLE 1.
    # Using dicts
    my_chart.title = {
        'align': 'center',
        'floating': True,
        'text': 'The Title for My Chart',
        'use_html': False,
    }

    my_chart.credits = {
        'enabled': True,
        'href': 'https://www.highchartspython.com/',
        'position': {
            'align': 'center',
            'vertical_align': 'bottom',
            'x': 123,
            'y': 456
        },
        'style': {
            'color': '#cccccc',
            'cursor': 'pointer',
            'font_size': '9px'
        },
        'text': 'Chris Modzelewski'
    }

    # EXAMPLE 2.
    # Using direct objects
    from highcharts_core.options.title import Title
    from highcharts_core.options.credits import Credits

    my_title = Title(text = 'The Title for My Chart',
                     floating = True, 
                     align = 'center')
    my_chart.options.title = my_title

    my_credits = Credits(text = 'Chris Modzelewski', 
                         enabled = True, 
                         href = 'https://www.highchartspython.com')
    my_chart.options.credits = my_credits

5. Generate the JavaScript Code for Your Chart
=================================================

Now having configured your chart in full, you can easily generate the JavaScript code
that will render the chart wherever it is you want it to go:

  .. code-block:: python

    # EXAMPLE 1.
    # as a string
    js_as_str = my_chart.to_js_literal()

    # EXAMPLE 2.
    # to a file (and as a string)
    js_as_str = my_chart.to_js_literal(filename = 'my_target_file.js')


6. Generate the JavaScript Code for Your Global Settings (optional)
=========================================================================

  .. code-block:: python

    # as a string
    global_settings_js = my_global_settings.to_js_literal()

    # to a file (and as a string)
    global_settings_js = my_global_settings.to_js_literal('my_target_file.js')


7. Generate a Static Version of Your Chart
==============================================

  .. code-block:: python

    # as in-memory bytes
    my_image_bytes = my_chart.download_chart(format = 'png')

    # to an image file (and as in-memory bytes)
    my_image_bytes = my_chart.download_chart(filename = 'my_target_file.png',
                                             format = 'png')


8. Render Your Chart in a Jupyter Notebook
===============================================

  .. code-block:: python

    my_chart.display()

--------------

***********************
Getting Help/Support
***********************

The **Highcharts for Python** toolkit comes with all of the great support that 
you are used to from working with the Highcharts JavaScript libraries. When you 
license the toolkit, you are welcome to use any of the following tools to get 
help using the toolkit. In particular, you can:

  * Use the `Highcharts Forums <https://highcharts.com/forum>`__
  * Use `Stack Overflow <https://stackoverflow.com/questions/tagged/highcharts-for-python>`__ with the 
    ``highcharts-for-python`` tag
  * `Report bugs or request features <https://github.com/highcharts-for-python/highcharts-core/issues>`__  in the 
    library's Github repository
  * `File a support ticket <https://www.highchartspython.com/get-help>`__ with us
  * `Schedule a live chat or video call <https://www.highchartspython.com/get-help>`__ with us

**FOR MORE INFORMATION:** https://www.highchartspython.com/get-help

-----------------

*********************
Contributing
*********************

We welcome contributions and pull requests! For more information, please see the
`Contributor Guide <https://core-docs.highchartspython.com/en/latest/contributing.html>`__. 
And thanks to all those who've already contributed!

-------------------

*********************
Testing
*********************

We use `TravisCI <https://travisci.com>`_ for our build automation and
`ReadTheDocs <https://readthedocs.com>`_ for our documentation.

Detailed information about our test suite and how to run tests locally can be
found in our Testing Reference.

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "highcharts-core",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.10",
    "maintainer_email": null,
    "keywords": "charts, data visualization, data viz, graphing, highcharts, highcharts JS, plotting",
    "author": null,
    "author_email": "HCP LLC <support@highchartspython.com>",
    "download_url": "https://files.pythonhosted.org/packages/62/ab/0feab74a1fb70e9224417b6f3fe324532bfaa9a01b898ab5676dc496dda0/highcharts_core-1.7.0.tar.gz",
    "platform": null,
    "description": "###################################################\nHighcharts Core for Python\n###################################################\n\n**High-end data visualization for the Python ecosystem**\n\n**Highcharts Core for Python** is a Python library that provides a Python wrapper\nfor the `Highcharts Core <https://www.highcharts.com/products/highcharts/>`__ JavaScript data\nvisualization library, with full integration into the robust Python ecosystem, including: \n\n  * **Jupyter Labs/Notebook**. You can now produce high-end and interactive plots and\n    renders using the full suite of Highcharts visualization capabilities.\n  * **Pandas**. Automatically produce data visualizations from your Pandas dataframes\n  * **PySpark**. Automatically produce data visualizations from data in a PySpark\n    dataframe.\n  * ...and even more use-case specific integrations across the broader toolkit.\n\nThe library supports Highcharts (JS) v.10.2 and higher, including Highcharts (JS) v.11.4.0.\n\n**COMPLETE DOCUMENTATION:** https://core-docs.highchartspython.com/en/latest/index.html\n\n-------------\n\n***************************************\nThe Highcharts for Python Toolkit\n***************************************\n\nThe **Highcharts Core for Python** library is - as the name suggests - the core library in \nthe broader `Highcharts for Python Toolkit <https://www.highcharts.com/integrations/python>`__, \nwhich together provides comprehensive support across the entire \n`Highcharts <https://www.highcharts.com>`__ suite of data visualization libraries:\n\n.. list-table::\n  :widths: 30 30 40\n  :header-rows: 1\n\n  * - Python Library\n    - JavaScript Library\n    - Description\n  * - **Highcharts Core for Python** \n    - `Highcharts Core (JS) <https://www.highcharts.com/products/highcharts/>`__\n    - (this library) the core Highcharts data visualization library\n  * - `Highcharts Stock for Python <https://stock-docs.highchartspython.com/>`__ \n    - `Highcharts Stock (JS) <https://www.highcharts.com/products/stock/>`__\n    - the time series visualization extension to Highcharts Core\n  * - `Highcharts Maps for Python <https://maps-docs.highchartspython.com/>`__ \n    - `Highcharts Maps (JS) <https://www.highcharts.com/products/maps/>`__\n    - the map visualization extension to Highcharts Core\n  * - `Highcharts Gantt for Python <https://gantt-docs.highchartspython.com/>`__\n    - `Highcharts Gantt (JS) <https://www.highcharts.com/products/gantt/>`__\n    - the Gantt charting extension to Highcharts Core\n  * - (all libraries in the Python toolkit)\n    - The **Highcharts Export Server** \n    - enabling the programmatic creation of static (downloadable) data visualizations\n\n--------------------\n\n***************\nInstallation\n***************\n\nTo install **Highcharts Core for Python**, just execute:\n\n.. code:: bash\n\n $ pip install highcharts-core\n\nBefore you install, please be aware of the following \"hard\" dependencies:\n\n  * Python 3.10 or higher\n  * Highcharts Core (JS) v.10.2 or higher (not technically a Python dependency, but \n    it won't work with earlier versions of Highcharts)\n  * `esprima-python <https://github.com/Kronuz/esprima-python>`__ v.4.0 or higher\n  * `requests <https://requests.readthedocs.io/en/latest/>`__ v.2.31 or higher\n  * `validator-collection <https://validator-collection.readthedocs.io/en/latest/>`__\n    v.1.5 or higher\n\nYou can find more information about soft and development dependencies in the\n`complete documentation <https://core-docs.highchartspython.com/en/latest/#dependencies>`__.\n\n-------------\n\n************************************\nWhy Highcharts for Python?\n************************************\n\n`Highcharts <https://www.highcharts.com>`__ is the world's most popular, most powerful, \ncategory-defining JavaScript data visualization library. If you are building a web or \nmobile app/dashboard that will be visualizing data in some fashion, you should \nabsolutely take a look at the Highcharts suite of solutions. Take a peak at some \nfantastic `demo visualizations <https://www.highcharts.com/demo>`__.\n\nAs a suite of JavaScript libraries, `Highcharts <https://www.highcharts.com>`__ is \nwritten in JavaScript, and is used to configure and render data visualizations in a\nweb browser (or other JavaScript-executing) environment. As a set of JavaScript\nlibraries, its audience is JavaScript developers. But what about the broader ecosystem of\nPython developers and data scientists?\n\nGiven Python's increasing adoption as the technology of choice for data science and for\nthe backends of leading enterprise-grade applications, Python is often the backend that \ndelivers data and content to the front-end...which then renders it using JavaScript and \nHTML.\n\nThere are numerous Python frameworks (Django, Flask, Tornado, etc.) with specific\ncapabilities to simplify integration with Javascript frontend frameworks (React, Angular,\nVueJS, etc.). But facilitating that with Highcharts has historically been very difficult.\nPart of this difficulty is because the Highcharts JavaScript suite - while supporting JSON as a\nserialization/deserialization format - leverages JavaScript object literals to expose the\nfull power and interactivity of its data visualizations. And while it's easy to serialize\nJSON from Python, serializing and deserializing to/from JavaScript object literal notation\nis much more complicated. \n\nThis means that Python developers looking to integrate with Highcharts typically had to \neither invest a lot of effort, or were only able to leverage a small portion of Highcharts' \nrich functionality.\n\nSo we wrote the **Highcharts for Python** toolkit to bridge that gap.\n\n**Highcharts for Python** provides Python object representation for *all* of the\nJavaScript objects defined in the\n`Highcharts (JavaScript) API <https://api.highcharts.com/highcharts/>`__. It provides automatic \ndata validation, and exposes simple and standardized methods for serializing those Python\nobjects back-and-forth to JavaScript object literal notation.\n\n\nKey Highcharts Core for Python Features\n===========================================\n\n* **Clean and consistent API**. No reliance on \"hacky\" code, ``dict``\n  and JSON serialization, or impossible to maintain / copy-pasted \"spaghetti code\".\n* **Comprehensive Highcharts Support**. Every single Highcharts chart type and every\n  single configuration option is supported in the **Highcharts for Python** toolkit.\n  Highcharts Core for Python includes support for the over 70 data visualization types \n  supported by `Highcharts Core <https://www.highcharts.com/product/highcharts/>`__ and \n  while other libraries in the toolkit support the 50+ technical indicator visualizations \n  available in `Highcharts Stock <https://www.highcharts.com/product/stock/>`__. \n  \n  Every Highcharts for Python library provides full support for the rich JavaScript \n  formatter (JS callback functions) capabilities that are often needed to get the most \n  out of Highcharts' visualization and interaction capabilities.\n\n  .. note:: \n    \n    **See Also**\n\n    * `Supported Visualizations <https://core-docs.highchartspython.com/en/latest/visualizations.html>`__\n\n* **Simple JavaScript Code Generation**. With one method call, produce production-ready\n  JavaScript code to render your interactive visualizations using Highcharts' rich\n  capabilities.\n* **Easy and Robust Chart Download**. With one method call, produce high-end static\n  visualizations that can be downloaded or shared as files with your audience. Produce\n  static charts using the Highsoft-provided **Highcharts Export Server**, or using your \n  own private export server as needed.\n* **Integration with Pandas and PySpark**. With two lines of code, produce a high-end\n  interactive visualization of your Pandas or PySpark dataframe.\n* **Consistent code style**. For Python developers, switching between Pythonic code\n  conventions and JavaScript code conventions can be...annoying. So\n  the Highcharts for Python toolkit applies Pythonic syntax with automatic conversion between\n  Pythonic ``snake_case`` notation and JavaScript ``camelCase`` styles.\n\n|\n\n**Highcharts for Python** vs Alternatives\n==============================================\n\nFor a discussion of **Highcharts for Python** in comparison to alternatives, please see\nthe **COMPLETE DOCUMENTATION:** https://core-docs.highchartspython.com/en/latest/index.html\n\n---------------------\n\n********************************\nHello World, and Basic Usage\n********************************\n\n1. Import Highcharts Core for Python\n==========================================\n\n.. code-block:: python\n  \n  # PRECISE-LOCATION PATTERN: BEST PRACTICE!\n  # This method of importing Highcharts for Python objects yields the fastest\n  # performance for the import statement. However, it is more verbose and requires\n  # you to navigate the extensive Highcharts Core for Python API.\n\n  # Import classes using precise module indications. For example:\n  from highcharts_core.chart import Chart\n  from highcharts_core.global_options.shared_options import SharedOptions\n  from highcharts_core.options import HighchartsOptions\n  from highcharts_core.options.plot_options.bar import BarOptions\n  from highcharts_core.options.series.bar import BarSeries\n\n  # CATCH-ALL PATTERN\n  # This method of importing Highcharts for Python classes has relatively slow\n  # performance because it imports hundreds of different classes from across the entire\n  # library. This performance impact may be acceptable to you in your use-case, but\n  # do use at your own risk.\n\n  # Import objects from the catch-all \".highcharts\" module.\n  from highcharts_core import highcharts\n\n  # You can now access specific classes without individual import statements.\n  highcharts.Chart\n  highcharts.SharedOptions\n  highcharts.HighchartsOptions\n  highcharts.BarOptions\n  highcharts.BarSeries\n\n\n2. Create Your Chart\n================================\n\n  .. code-block:: python\n\n    # from a primitive array, using keyword arguments\n    my_chart = Chart(data = [[1, 23], [2, 34], [3, 45]], \n                     series_type = 'line')\n\n    # from a primitive array, using the .from_array() method\n    my_chart = Chart.from_array([[1, 23], [2, 34], [3, 45]], \n                                series_type = 'line')\n\n    # from a Numpy ndarray, using keyword arguments\n    my_chart = Chart(data = numpy_array, series_type = 'line')\n\n    # from a Numpy ndarray, using the .from_array() method\n    my_chart = Chart.from_array(data = numpy_array, series_type = 'line')\n\n    # from a JavaScript file\n    my_chart = Chart.from_js_literal('my_js_literal.js')\n\n    # from a JSON file\n    my_chart = Chart.from_json('my_json.json')\n\n    # from a Python dict\n    my_chart = Chart.from_dict(my_dict_obj)\n\n    # from a Pandas dataframe\n    my_chart = Chart.from_pandas(df)\n\n    # from a PySpark dataframe\n    my_chart = Chart.from_pyspark(df,\n                                  property_map = {\n                                      'x': 'transactionDate',\n                                      'y': 'invoiceAmt',\n                                      'id': 'id'\n                                  },\n                                  series_type = 'line')\n\n    # from a CSV\n    my_chart = Chart.from_csv('/some_file_location/filename.csv')\n\n    # from a HighchartsOptions configuration object\n    my_chart = Chart.from_options(my_options)\n\n    # from a Series configuration, using keyword arguments\n    my_chart = Chart(series = my_series)\n\n    # from a Series configuration, using .from_series()\n    my_chart = Chart.from_series(my_series)\n    \n3. Configure Global Settings (optional)\n=============================================\n\n  .. code-block:: python\n\n    # Import SharedOptions\n    from highcharts_core.global_options.shared_options import SharedOptions\n\n    # from a JavaScript file\n    my_global_settings = SharedOptions.from_js_literal('my_js_literal.js')\n\n    # from a JSON file\n    my_global_settings = SharedOptions.from_json('my_json.json')\n\n    # from a Python dict\n    my_global_settings = SharedOptions.from_dict(my_dict_obj)\n\n    # from a HighchartsOptions configuration object\n    my_global_settings = SharedOptions.from_options(my_options)\n\n\n4. Configure Your Chart / Global Settings\n================================================\n\n  .. code-block:: python\n\n    from highcharts_core.options.title import Title\n    from highcharts_core.options.credits import Credits\n\n    # EXAMPLE 1.\n    # Using dicts\n    my_chart.title = {\n        'align': 'center',\n        'floating': True,\n        'text': 'The Title for My Chart',\n        'use_html': False,\n    }\n\n    my_chart.credits = {\n        'enabled': True,\n        'href': 'https://www.highchartspython.com/',\n        'position': {\n            'align': 'center',\n            'vertical_align': 'bottom',\n            'x': 123,\n            'y': 456\n        },\n        'style': {\n            'color': '#cccccc',\n            'cursor': 'pointer',\n            'font_size': '9px'\n        },\n        'text': 'Chris Modzelewski'\n    }\n\n    # EXAMPLE 2.\n    # Using direct objects\n    from highcharts_core.options.title import Title\n    from highcharts_core.options.credits import Credits\n\n    my_title = Title(text = 'The Title for My Chart',\n                     floating = True, \n                     align = 'center')\n    my_chart.options.title = my_title\n\n    my_credits = Credits(text = 'Chris Modzelewski', \n                         enabled = True, \n                         href = 'https://www.highchartspython.com')\n    my_chart.options.credits = my_credits\n\n5. Generate the JavaScript Code for Your Chart\n=================================================\n\nNow having configured your chart in full, you can easily generate the JavaScript code\nthat will render the chart wherever it is you want it to go:\n\n  .. code-block:: python\n\n    # EXAMPLE 1.\n    # as a string\n    js_as_str = my_chart.to_js_literal()\n\n    # EXAMPLE 2.\n    # to a file (and as a string)\n    js_as_str = my_chart.to_js_literal(filename = 'my_target_file.js')\n\n\n6. Generate the JavaScript Code for Your Global Settings (optional)\n=========================================================================\n\n  .. code-block:: python\n\n    # as a string\n    global_settings_js = my_global_settings.to_js_literal()\n\n    # to a file (and as a string)\n    global_settings_js = my_global_settings.to_js_literal('my_target_file.js')\n\n\n7. Generate a Static Version of Your Chart\n==============================================\n\n  .. code-block:: python\n\n    # as in-memory bytes\n    my_image_bytes = my_chart.download_chart(format = 'png')\n\n    # to an image file (and as in-memory bytes)\n    my_image_bytes = my_chart.download_chart(filename = 'my_target_file.png',\n                                             format = 'png')\n\n\n8. Render Your Chart in a Jupyter Notebook\n===============================================\n\n  .. code-block:: python\n\n    my_chart.display()\n\n--------------\n\n***********************\nGetting Help/Support\n***********************\n\nThe **Highcharts for Python** toolkit comes with all of the great support that \nyou are used to from working with the Highcharts JavaScript libraries. When you \nlicense the toolkit, you are welcome to use any of the following tools to get \nhelp using the toolkit. In particular, you can:\n\n  * Use the `Highcharts Forums <https://highcharts.com/forum>`__\n  * Use `Stack Overflow <https://stackoverflow.com/questions/tagged/highcharts-for-python>`__ with the \n    ``highcharts-for-python`` tag\n  * `Report bugs or request features <https://github.com/highcharts-for-python/highcharts-core/issues>`__  in the \n    library's Github repository\n  * `File a support ticket <https://www.highchartspython.com/get-help>`__ with us\n  * `Schedule a live chat or video call <https://www.highchartspython.com/get-help>`__ with us\n\n**FOR MORE INFORMATION:** https://www.highchartspython.com/get-help\n\n-----------------\n\n*********************\nContributing\n*********************\n\nWe welcome contributions and pull requests! For more information, please see the\n`Contributor Guide <https://core-docs.highchartspython.com/en/latest/contributing.html>`__. \nAnd thanks to all those who've already contributed!\n\n-------------------\n\n*********************\nTesting\n*********************\n\nWe use `TravisCI <https://travisci.com>`_ for our build automation and\n`ReadTheDocs <https://readthedocs.com>`_ for our documentation.\n\nDetailed information about our test suite and how to run tests locally can be\nfound in our Testing Reference.\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "High-end Data Visualization for the Python Ecosystem. Official wrapper for Highcharts Core (JS).",
    "version": "1.7.0",
    "project_urls": {
        "Bug Tracker": "https://github.com/highcharts-for-python/highcharts-core/issues",
        "Demo": "https://github.com/highcharts-for-python/highcharts-for-python-demos",
        "Documentation": "https://core-docs.highchartspython.com/en/latest/",
        "History": "https://github.com/highcharts-for-python/highcharts-core/blob/master/CHANGES.rst",
        "Homepage": "https://highchartspython.com",
        "Source Code": "https://github.com/highcharts-for-python/highcharts-core",
        "Sponsor": "https://github.com/sponsors/highcharts-for-python",
        "Support": "https://www.highchartspython.com/get-help"
    },
    "split_keywords": [
        "charts",
        " data visualization",
        " data viz",
        " graphing",
        " highcharts",
        " highcharts js",
        " plotting"
    ],
    "urls": [
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "5cd3fad79a8215c2bb8b1e5f4c135fb514935bc37b9762d5fb88bc0a0fdad12a",
                "md5": "cbeababde15379597b1e2b4accaec600",
                "sha256": "0f0ef34f17f7c17f5125b5159e09a5556d7e8d4fffc77c123accac7325034a8a"
            },
            "downloads": -1,
            "filename": "highcharts_core-1.7.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "cbeababde15379597b1e2b4accaec600",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.10",
            "size": 679048,
            "upload_time": "2024-04-07T18:26:44",
            "upload_time_iso_8601": "2024-04-07T18:26:44.842085Z",
            "url": "https://files.pythonhosted.org/packages/5c/d3/fad79a8215c2bb8b1e5f4c135fb514935bc37b9762d5fb88bc0a0fdad12a/highcharts_core-1.7.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "62ab0feab74a1fb70e9224417b6f3fe324532bfaa9a01b898ab5676dc496dda0",
                "md5": "431dd1a0a4e638d8fbabb25fafea9332",
                "sha256": "b0464d5845499bcc149dc93f58ecbebe3be6a11a1558c5c3325c175deb45395a"
            },
            "downloads": -1,
            "filename": "highcharts_core-1.7.0.tar.gz",
            "has_sig": false,
            "md5_digest": "431dd1a0a4e638d8fbabb25fafea9332",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.10",
            "size": 12098473,
            "upload_time": "2024-04-07T18:26:48",
            "upload_time_iso_8601": "2024-04-07T18:26:48.059137Z",
            "url": "https://files.pythonhosted.org/packages/62/ab/0feab74a1fb70e9224417b6f3fe324532bfaa9a01b898ab5676dc496dda0/highcharts_core-1.7.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-04-07 18:26:48",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "highcharts-for-python",
    "github_project": "highcharts-core",
    "travis_ci": true,
    "coveralls": false,
    "github_actions": true,
    "requirements": [
        {
            "name": "esprima",
            "specs": [
                [
                    "==",
                    "4.0.1"
                ]
            ]
        },
        {
            "name": "requests",
            "specs": [
                [
                    "==",
                    "2.31.0"
                ]
            ]
        },
        {
            "name": "validator-collection",
            "specs": [
                [
                    "==",
                    "1.5.0"
                ]
            ]
        }
    ],
    "tox": true,
    "lcname": "highcharts-core"
}
        
Elapsed time: 0.22249s