Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/leifg/excellent

Excel Parser written in Elixir (currently only Excel 2000)
https://github.com/leifg/excellent

Last synced: 3 months ago
JSON representation

Excel Parser written in Elixir (currently only Excel 2000)

Awesome Lists containing this project

README

        

# Excellent

[![Build Status](https://travis-ci.org/leifg/excellent.svg?branch=master)](https://travis-ci.org/leifg/excellent)
[![Coverage Status](https://coveralls.io/repos/leifg/excellent/badge.png?branch=master)](https://coveralls.io/r/leifg/excellent?branch=master)
[![hex.pm version](https://img.shields.io/hexpm/v/excellent.svg?style=flat)](https://hex.pm/packages/excellent)

**DISCLAIMER:** Completely abandoned. No further development will take place.
If you're looking for an xlxs parsing library, consider using [xlsxir](https://github.com/jsonkenl/xlsxir)

This is a library for parsing `.xlsx` files (Open XML format). It is targeted for reading Excel 2000 files into a list of lists.

Sample output:

```elixir
[
["A1", "B1", "C1", "D1"],
["A2", "B2", "C2", "D2"],
["A3", "B3", "C3", "D3"],
["A4", "B4", "C4", "D4"],
["A5", "B5", "C5", "D5"],
]
```

## Installation

You can add Excellent as a dependency in your `mix.exs` file. Since it only requires Elixir and Erlang there are no other dependencies.

```elixir
def deps do
[ { :excellent, "~> 0.0.1" } ]
end
```

If you aren't using hex, add the a reference to the github repo.

``` elixir
def deps do
[ { :excellent, github: "leifg/excellent" } ]
end
```

Then run `mix deps.get` in the shell to fetch and compile the dependencies

## Usage

The top level funtion takes 2 arguments: the filename and the number of the worksheet you want to parse (zero based).

```elixir
Excellent.parse('spreadsheet.xlsx', 0)

=> [
["A1", "B1", "C1", "D1"],
["A2", "B2", "C2", "D2"],
["A3", "B3", "C3", "D3"],
["A4", "B4", "C4", "D4"],
["A5", "B5", "C5", "D5"],
]
```

There is also a function to return the names of the worksheets as a tuple:

```elixir
Excellent.worksheet_names('spreadsheet.xlsx')

=> {"Worksheet 1", "Worksheet 2"}
```

## TODO

- Read worksheets as stream from ZIP archive
- Implement different data types (curently only strings and numbers are supported)