Metadata-Version: 2.1
Name: pycel
Version: 1.0b30
Summary: A library for compiling excel spreadsheets to python code & visualizing them as a graph
Home-page: https://github.com/stephenrauch/pycel
Author: Dirk Gorissen, Stephen Rauch
Author-email: dgorissen@gmail.com
Maintainer: Stephen Rauch
Maintainer-email: stephen.rauch+pycel@gmail.com
License: UNKNOWN
Project-URL: Tracker, https://github.com/stephenrauch/pycel/issues
Keywords: excel compiler formula parser
Platform: UNKNOWN
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: GNU General Public License v3 (GPLv3)
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Requires-Python: >=3.6
License-File: LICENSE.txt

Pycel
=====

|build-state| |coverage| |requirements|

|pypi| |pypi-pyversions| |repo-size| |code-size|

Pycel is a small python library that can translate an Excel spreadsheet into
executable python code which can be run independently of Excel.

The python code is based on a graph and uses caching & lazy evaluation to
ensure (relatively) fast execution.  The graph can be exported and analyzed
using tools like `Gephi <http://www.gephi.org>`_. See the contained example
for an illustration.

Required python libraries:
    `dateutil <https://dateutil.readthedocs.io/en/stable/>`_,
    `networkx <https://networkx.github.io/>`_,
    `numpy <https://www.numpy.org/>`_,
    `openpyxl <https://openpyxl.readthedocs.io/en/stable/>`_,
    `ruamel.yaml <https://yaml.readthedocs.io/en/latest/>`_, and optionally:
    `matplotlib <https://matplotlib.org/>`_,
    `pydot <https://github.com/pydot/pydot>`_

The full motivation behind pycel including some examples & screenshots is
described in this `blog post <http://www.dirkgorissen.com/2011/10/19/
pycel-compiling-excel-spreadsheets-to-python-and-making-pretty-pictures/>`_.

Usage
======

Download the library and run the example file.

**Quick start:**
You can use binder to see and explore the tool quickly and interactively in the
browser: |notebook|

**The good:**

All the main mathematical functions (sin, cos, atan2, ...) and operators
(+,/,^, ...) are supported as are ranges (A5:D7), and functions like
MIN, MAX, INDEX, LOOKUP, and LINEST.

The codebase is small, relatively fast and should be easy to understand
and extend.

I have tested it extensively on spreadsheets with 10 sheets & more than
10000 formulae.  In that case calculation of the equations takes about 50ms
and agrees with Excel up to 5 decimal places.

**The bad:**

My development is driven by the particular spreadsheets I need to handle so
I have only added support for functions that I need.  However, it is should be
straightforward to add support for others.

The code does currently support cell references so a function like OFFSET works,
but suffers from the fact that if a cell is not already compiled in, then the
function can fail.  Also, for obvious reasons, any VBA code is not compiled
but needs to be re-implemented manually on the python side.

**The Ugly:**

The resulting graph-based code is fast enough for my purposes but to make it
truly fast you would probably replace the graph with a dependency tracker
based on sparse matrices or something similar.

Excel Addin
===========

It's possible to run pycel as an excel addin using
`PyXLL <http://www.pyxll.com/>`_. Simply place pyxll.xll and pyxll.py in the
lib directory and add the xll file to the Excel Addins list as explained in
the pyxll documentation.

Acknowledgements
================

This code was originally made possible thanks to the python port of
Eric Bachtal's `Excel formula parsing code
<http://ewbi.blogs.com/develops/popular/excelformulaparsing.html>`_
by Robin Macharg.

The code currently uses a tokenizer of similar origin from the
`openpyxl library.
<https://foss.heptapod.net/openpyxl/openpyxl/-/tree/branch/default/openpyxl/formula/>`_

.. Image links

.. |build-state| image:: https://travis-ci.com/dgorissen/pycel.svg?branch=master
  :target: https://travis-ci.com/dgorissen/pycel
  :alt: Build Status

.. |coverage| image:: https://codecov.io/gh/dgorissen/pycel/branch/master/graph/badge.svg
  :target: https://codecov.io/gh/dgorissen/pycel/list/master
  :alt: Code Coverage

.. |pypi| image:: https://img.shields.io/pypi/v/pycel.svg
  :target: https://pypi.org/project/pycel/
  :alt: Latest Release

.. |pypi-pyversions| image:: https://img.shields.io/pypi/pyversions/pycel.svg
    :target: https://pypi.python.org/pypi/pycel

.. |requirements| image:: https://requires.io/github/stephenrauch/pycel/requirements.svg?branch=master
  :target: https://requires.io/github/stephenrauch/pycel/requirements/?branch=master
  :alt: Requirements Status

.. |repo-size| image:: https://img.shields.io/github/repo-size/dgorissen/pycel.svg
  :target: https://github.com/dgorissen/pycel
  :alt: Repo Size

.. |code-size| image:: https://img.shields.io/github/languages/code-size/dgorissen/pycel.svg
  :target: https://github.com/dgorissen/pycel
  :alt: Code Size

.. |notebook| image:: https://mybinder.org/badge.svg
  :target: https://mybinder.org/v2/gh/dgorissen/pycel/master?filepath=notebooks%2Fexample.ipynb
  :alt: Open Notebook


Change Log
==========

[1.0b30] - 2021-10-13
=====================

Changed
-------

- Better handle indirect cells in compiled workbooks
- Better handle numpy floats in compiled workbooks


[1.0b29] - 2021-09-13
=====================

Added
-----

- Add support for openpyxl >= 3.0.8


[1.0b28] - 2021-08-31
=====================

Added
-----

- Add support for networkx 2.6

Changed
-------

- Some minor improvements for Iterative Calculations


[1.0b27] - 2021-07-10
=====================

Added
-----

* Added CHOOSE() function
* Added FORECAST() function
* Added INTERCEPT() function
* Added IFNA() function
* Added ISBLANK() function
* Added ISLOGICAL() function
* Added ISNONTEXT() function
* Added N() function
* Added NA() function
* Added SLOPE() function
* Added SUBSTITUTE() function
* Added TEXT() function  (Thanks, Luckykarter)
* Added TREND() function
* Added Reference Form for INDEX()
* Added str_params to excel_helper()
* Added ExcelCompiler.validate_serialized()

Changed
-------

* Improve LINEST() compatibilty w/ Excel
* Improve TEXT() compatibilty w/ Excel
* Improve error and number handling in some Text functions
* Improve IFS() to support array context
* Missing references from INDIRECT() and OFFSET() resolve more often

Fixed
-----

* Fix #111, Incorrect implementation of YEARFRAC
* Fixed some exceptions in LINEST()
* Fix serialize ranges with formulas
* Fixed a minor bug in DATE()
* Fixed TIMEVALUE() parsing for elapsed times


[1.0b26] - 2021-06-18
=====================

Added
-----

* Python 3.9 now supported
* Add bitwise functions: bitand, bitor, bitxor, bitlshift and bitrshift (Thanks, bogdan-oprescu-nxp)
* Add PV function (Thanks, estandiaa-marain)

Changed
-------

* Allow plugins to be passed to the deserialization function from_file() (Thanks, nanaposo)

Removed
-------

* Drop support for Python 3.5

Fixed
-----
* Fix openpyxl >= 3.0.4 (Thanks, ckp95)
* Fix HLOOKUP row_index_num validation to use num rows (Thanks, nanaposo)
* Fix #86, tokenize.TokenError: ('EOF in multi-line statement',
* Fix #88, Handle calcPR in workbook (Thanks, andreif)
* Fix #89, NPV function fails when passed range of cashflows (Thanks, jpp-0)
* Fix #93, AssertionError during set_value(), by adding a better error message
* Fix #99, Pycel raises NotImplementedError on rectangular ranges (Thanks, rmorel)
* Fix #103, build_operator_operand_fixup() throws #VALUE error when concatenating AddressCell objects (Thanks, nboukraa)
* Fix #104, Insufficient coverage and testing after recent merges
* Fix #105, Incorrect RPN for expressions with consecutive negations (Thanks, victorjmarin)
* Fix #109, String concatenation fails for particular cases (Thanks, bogdan-oprescu-nxp)
* Fix issue in =IF() when comparing to numpy result
* Fix MID() and REPLACE() and LEN() in a CSE context
* Fix INDEX() error handling
* Fix error handling for lookup variants


[1.0b22] - 2019-10-17
=====================

Fixed
-----
* Fix #80, incompatible w/ networkx 2.4


[1.0b21] - 2019-10-13
=====================

Changed
-------

* Speed up compile
* Implement defined names in multicolon ranges
* Tokenize ':' when adjoining functions as infix operator
* Various changes in prep to improve references, including
* Add reference expansion to function helpers
* Add sheet to indirect() and ref_param=0 to offset()
* Implement is_address() helper
* Implement intersection and union for AddressCell

Fixed
-----
* Fix #77, empty arg in IFERROR()
* Fix #78, None compare and cleanup error handling for various IFS() funcs


[1.0b20] - 2019-09-22
=====================

Changed
-------

* Implement multi colon ranges
* Add support for missing (empty) function parameters

Fixed
-----
* Fix threading issue in iterative evaluator
* Fix range intersection with null result for ROW and COLUMN
* Fix #74 - Count not working for ranges


[1.0b19] - 2019-09-12
=====================

Changed
-------

* Implement INDIRECT & OFFSET
* Implement SMALL, LARGE & ROUNDDOWN  (Thanks, nanaposo)
* Add error message for unhandled missing function parameter

Fixed
-----
* Fix threading issue w/ CSE evaluator


[1.0b18] - 2019-09-07
=====================

Changed
-------

* Implement CEILING_MATH, CEILING_PRECISION, FLOOR_MATH & FLOOR_PRECISION
* Implement FACT & FACTDOUBLE
* Implement AVERAGEIF, MAXIFS, MINIFS
* Implement ODD, EVEN, ISODD, ISEVEN, SIGN

Fixed
-----
* Fix #67 - Evaluation with unbounded range
* Fix bugs w/ single cells for xIFS functions


[1.0b17] - 2019-09-02
=====================

Changed
-------
* Add Formula Support for Multi Area Ranges from defined names
* Allow ExcelCompiler init from openpyxl workbook
* Implement LOWER(), REPLACE(), TRIM() & UPPER()
* Implement DATEVALUE(), IFS() and ISERR()  (Thanks, int128t)

* Reorganized time and time utils and text functions
* Add excelutil.AddressMultiAreaRange.
* Add abs_coordinate() property to AddressRange and AddressCell
* Cleanup import statements

Fixed
-----
* Resolved tox version issue on travis
* Fix defined names with Multi Area Range


[1.0b16] - 2019-07-07
=====================

Changed
-------
* Add twelve date and time functions
* Serialize workbook filename and use it instead of the serialization filename (Thanks, nanaposo)


[1.0b15] - 2019-06-30
=====================

Changed
-------
* Implement AVERAGEIFS()
* Take Iterative Calc Parameter defaults from workbook

Fixed
-----
* #60, Binder Notebook Example not Working


[1.0b14] - 2019-06-16
=====================

Changed
-------
* Added method to evaluate the conditional format (formulas) for a cell or cells
* Added ExcelCompiler(..., cycles=True) to allow Excel iterative calculations


[1.0b13] - 2019-05-10
=====================

Changed
-------
* Implement VALUE()
* Improve compile performance reversion from CSE work

Fixed
-----
* #54, In normalize_year(), month % 12 can be 0 -> IllegalMonthError


[1.0b12] - 2019-04-22
=====================

Changed
-------
* Add library plugin support
* Improve evaluate of unbounded row/col (ie: A:B)
* Fix some regressions from 1.0b11


[1.0b11] - 2019-04-21
=====================

Added
-----

* Implement LEFT()
* Implement ISERROR()
* Implement FIND()
* Implement ISNUMBER()
* Implement SUMPRODUCT()
* Implement CEILING()
* Implement TRUNC() and FLOOR()
* Add support for LOG()
* Improve ABS(), INT() and ROUND()

* Add quoted_address() method to AddressRange and AddressCell
* Add public interface to get list of formula_cells()
* Add NotImplementedError for "linked" sheet names
* Add reference URL to function info
* Added considerable extensions to CSE Array Formula Support
    * Add CSE Array handling to excelformula and excelcompiler
    * Change Row, Column & Index to rectangular arrays only
    * Add in_array_formula_context
    * Add cse_array_wrapper() to allow calling functions in array context
    * Add error_string_wrapper() to check for excel errors
    * Move math_wrap() to function_helpers.
    * Handle Direct CSE Array in cell
    * Reorganize CSE Array Formula handling in excelwrapper
    * For CSE Arrays that are smaller than target fill w/ None
    * Trim oversize array results to fit target range
    * Improve needed addresses parser from python code
    * Improve _coerce_to_number() and _numerics() for CSE arrays
    * Remove formulas from excelwrapper._OpxRange()

Changed
-------

* Refactored ExcelWrapper, ExcelFormula & ExcelCompiler to allow...
* Refactored function_helpers to add decorators for excelizing library functions
* Improved various messages and exceptions in validate_calcs() and trim_graph()
* Improve Some NotImplementedError() messages
* Only build compiler eval context once

Fixed
-----

* Address Range Union and Intersection need sheet_name
* Fix function info for paired functions from same line
* Fix Range Intersection
* Fix Unary Minus on Empty cell
* Fix ISNA()
* Fix AddressCell create from tuple
* Power(0,-1) now returns DIV0
* Cleanup index()


[1.0b8] - 2019-03-20
====================

Added
-----

* Implement operators for Array Formulas
* Implement concatenate and concat
* Implement subtotal
* Add support for expanding array formulas
* Add support for table relative references
* Add function information methods

Changed
-------

* Improve messages for validate_calcs and not implemented functions

Fixed
-----
* Fix column and row for array formulas


[1.0b7] - 2019-03-10
====================

Added
-----

* Implement Array (CSE) Formulas

Fixed
-----

* Fix #45 - Unbounded Range Addresses (ie: A:B or 1:2) broken


[1.0b6] - 2019-03-03
====================

Fixed
-----

* Fix #42 - 'ReadOnlyWorksheet' object has no attribute 'iter_cols'
* Fix #43 - Fix error with leading/trailing whitespace


[1.0b5] - 2019-02-24
====================

Added
-----

* Implement XOR(), NOT(), TRUE(), FALSE()
* Improve error handling for AND(), OR()
* Implement POWER() function


[1.0b4] - 2019-02-17
====================

Changed
-------

* Move to openpyxl 2.6+

Removed
-------

* Remove support for Python 3.4


[1.0b3] - 2019-02-02
====================

Changed
-------

* Work around openpyxl returning datetimes
* Pin to openpyxl 2.5.12 to avoid bug in 2.5.14 (fixed in PR #315)


[1.0b2] - 2019-01-05
====================

Changed
-------

* Much work to better match Excel error processing
* Extend validate_calcs() to allow testing entire workbook
* Improvements to match(), including wildcard support
* Finished implementing match(), lookup(), vlookup() and hlookup()
* Implement COLUMN() and ROW()
* Implement % operator
* Implement len()
* Implement binary base number Excel functions (hex2dec, etc.)

Fixed
-----

* Fix PI()


[1.0b0] - 2018-12-25
=====================

Added
-----

* Converted to Python 3.4+
* Removed Windows Excel COM driver (openpyxl is used for all xlsx reading)
* Add support for defined names
* Add support for structured references
* Fix support for relative formulas
* set_value() and evaluate() support ranges and lists
* Add several more library functions
* Add AddressRange and AddressCell classes to encapsulate address calcs
* Add validate_calcs() to aid debugging excellib functions
* Add `build` feature which can limit recompile to only when excel file changes

Changed
-------

* Improved handling for #DIV0! and #VALUE!
* Tests run on Python 3.4, 3.5, 3.6, 3.7 (via tox)
* Heavily refactored ExcelCompiler
* Moved all formula evaluation, parsing, etc, code to ExcelFormula class
* Convert to using openpyxl tokenizer
* Converted prints to logging calls
* Convert to using pytest
* Add support for travis and codecov.io
* 100% unit test coverage (mostly)
* Add debuggable formula evaluation
* Cleanup generated Python code to make easier to read
* Add a text format (yaml or json) serialization format
* flake8 (pep8) checks added
* pip now handles which Python versions can be used
* Release to PyPI
* Docs updated

Removed
-------

* Python 2 no longer supported

Fixed
-----

* Numerous


[0.0.1] - (UNRELEASED)
======================

* Original version available from `Dirk Ggorissen's Pycel Github Page`_.
* Supports Python 2

.. _Dirk Ggorissen's Pycel Github Page: https://github.com/dgorissen/pycel/tree/33c1370d499c629476c5506c7da308713b5842dc


