I have a spreadsheet that I’d like to compile into a form that I could call from C#.
Naturally, I’d like to be able to change the inputs to the spreadsheet before reading the calculated result.
What is your recommended method?
UPDATE:
To clarify, I want to make an existing Excel spreadsheet available as a web service that is callable from .NET. I can’t have a dependency on Excel, as its running on a web server.
UPDATE:
I used the answer below, and it worked like a charm. Now I can prototype a formula in Excel, then convert it straight into C# and compile it into an assembly.
This question is also covered under Reading Excel Files as a Server Process.
FlexCel API Mate within TMS Flexcel Studio for .NET lets you convert an existing Excel spreadsheet into C# code, recalculate the spreadsheet, and read the result out of a cell using an API call.
See the video tutorial of FlexCel ApiMate. The video states, quote:
The docs also state:
and:
UPDATE
Here is clarification from TMS tech support:
Emailed question:
I’d like to do the following:
In short, I want to use FlexCel as an “Webserver Excel calculation engine”, so we don’t have to have Excel installed on the web server to perform spreadsheet calculations.
Are the steps I’ve described possible? Or have I misunderstood how the component works?
Emailed reply:
Besides this, for using it as recalculation engine, we have the “RecalculateCell()” method that won’t recalculate the full spreadsheet, but only the cells needed to get the value in an specific cell. So, if for example your result is in A1, you can call RecalcCell in A1, and it will recalculate only all cells needed to get the value in A1 (including dependecies, so if A1 has a formula with a2, and a2 with a3, all 3 will be calculated).
There is also a RecalcExpression method, that will recalculate the value of any formula without needing to write it into a cell. So imagine you have a column of numbers at col A, and you want to know the sum. You could use RecalcExpression(“=sum(A:A)”); to know the sum, without needing to enter a formula in B1 with the sum and then reading the value of that formula (which you could also do of course)