# pyxll-jupyter **Repository Path**: gaoshann/pyxll-jupyter ## Basic Information - **Project Name**: pyxll-jupyter - **Description**: 搞笑excel插件,python实现方案 - **Primary Language**: Unknown - **License**: MIT - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 1 - **Created**: 2021-04-21 - **Last Updated**: 2021-11-04 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # PyXLL-Jupyter Integration for Jupyter notebooks and Microsoft Excel. See the [Python Jupyter Notebooks in Excel](https://www.pyxll.com/blog/python-jupyter-notebooks-in-excel/) blog post for more details. ## Requirements - PyXLL >= 5.0.0 - Jupyter >= 1.0.0 - notebook >= 6.0.0 - PySide2 ## Installation To install this package use: pip install pyxll-jupyter Once installed a "Jupyter Notebook" button will be added to the PyXLL ribbon tab in Excel, so long as you have PyXLL 5 or above already installed. When using Jupyter in Excel the Python kernel runs inside the Excel process using PyXLL. You can interact with Excel from code in the Jupyter notebook, and write Excel functions using the PyXLL decorators @xl_menu and @xl_macro etc. As the kernel runs in the existing Python interpreter in the Excel process it is not possible to restart the kernel or to use other Python versions or other languages. ## Configuration To configure add the following to your pyxll.cfg file (default values shown): [JUPYTER] use_workbook_dir = 0 notebook_dir = Documents timeout = 30 qt = PySide2 disable_ribbon = 0 If *use_workbook_dir* is set and the current workbook is saved then Jupyter will open in the same folder as the current workbook. If *disable_ribbon* is set then the ribbon button to start Jupyter will not be shown, however Jupyter may still be opened using the "OpenJupyterNotebook" macro. ### Qt The pyxll-jupyter package uses the Qt [QWebEngineView](https://doc.qt.io/qt-5/qwebengineview.html) widget, and by default will use the [PySide2](https://pypi.org/project/PySide2/) package. This can be changed to use [PyQt5](https://www.riverbankcomputing.com/software/pyqt/) by setting `qt = PyQt5` in the `JUPYTER` section of the config. You will need to have both the `pyqt5` and `pyqtwebengine` packages installed if using this option. Both can be installed using pip as follows: pip install pyqt5 pyqtwebengine ## Magic Functions The following magic functions are available in addition to the standard Jupyter magic functions: ``` %xl_get [-c CELL] [-t TYPE] [-x] Get the current selection in Excel into Python. optional arguments: -c CELL, --cell CELL Address of cell to get value of. -t TYPE, --type TYPE Datatype to convert the value to. -x, --no-auto-resize Don't auto-resize the range. ``` ``` %xl_set [-c CELL] [-t TYPE] [-f FORMATTER] [-x] value Set a value to the current selection in Excel. positional arguments: value Value to set in Excel. optional arguments: -c CELL, --cell CELL Address of cell to get value of. -t TYPE, --type TYPE Datatype to convert the value to. -f FORMATTER, --formatter FORMATTER PyXLL Formatter to use when setting the value. -x, --no-auto-resize Don't auto-resize the range. ``` ``` %xl_plot [-n NAME] [-c CELL] [-w WIDTH] [-h HEIGHT] figure Plot a figure to Excel in the same way as pyxll.plot. The figure is exported as an image and inserted into Excel as a Picture object. If the --name argument is used and the picture already exists then it will not be resized or moved. positional arguments: figure Figure to plot. optional arguments: -n NAME, --name NAME Name of the picture object in Excel to use. -c CELL, --cell CELL Address of cell to use when creating the Picture in Excel. -w WIDTH, --width WIDTH Width in points to use when creating the Picture in Excel. -h HEIGHT, --height HEIGHT Height in points to use when creating the Picture in Excel. ``` For more information about installing and using PyXLL see https://www.pyxll.com. Copyright (c) 2020 PyXLL Ltd