linux - Excel函数的命令行执行

标签 linux windows excel command-line

可以从命令行调用 Excel 函数吗?

我不想与任何文件进行任何交互。我只想像其他命令行工具一样使用这些功能。它应该只是服务于一些一次性的目的。

例如,如果有一种方法可以做这样的事情,我会很高兴:

$ excel roman(15)
XV

$ excel randbetween(10,20)
14

当然,并不是所有可用的功能都可以期望这样运行,但越多越好。

  1. 是否有任何 native 应用程序(在 Linux 或 Windows 上,但最好是跨平台的) 提供这种选择?

  2. 或者有什么方法可以操纵 excel 本身来做到这一点 (尽管根据我搜索的内容,这似乎并不 可能)?

最佳答案

libformula可能是一个很好的起点。这是一个概念证明:

$ excel 'TRIM(" abc 123  ")'
abc 123

excel 是这个简单的 shell 脚本:

#!/bin/sh

java -cp /usr/share/java/commons-logging.jar:libformula/demo:libbase/dist/libbase-6.1-SNAPSHOT.jar:libformula/dist/libformula-6.1-SNAPSHOT.jar:/home/cwarden/git/excel/src org.xerus.excel.Excel "$1"

org.xerus.excel.Excel 从 argv 中获取一个字符串并将其计算为一个公式:

package org.xerus.excel;

import org.pentaho.reporting.libraries.formula.EvaluationException;
import org.pentaho.reporting.libraries.formula.Formula;
import org.pentaho.reporting.libraries.formula.DefaultFormulaContext;
import org.pentaho.reporting.libraries.formula.parser.ParseException;

public class Excel {
        public static void main(final String[] args) throws ParseException, EvaluationException {
                final Formula f = new Formula(args[0]);
                f.initialize(new DefaultFormulaContext());
                final Object o = f.evaluate();
                System.out.println(o);
        }
}

libformula 包含一个演示程序,org.pentaho.reporting.libraries.formula.demo.PrintAllFunctions,它打印出所有支持的函数:

Category User-Defined
ARRAYCONCATENATE, ARRAYCONTAINS, ARRAYLEFT, ARRAYMID, CSVARRAY, CSVTEXT, NORMALIZEARRAY, NULL, PARSEDATE, SEQUENCEQUOTER
Category Information
CHOOSE, COUNT, COUNTA, COUNTBLANK, ERROR, HASCHANGED, INDEX, ISBLANK, ISERR, ISERROR, ISEVEN, ISLOGICAL, ISNA, ISNONTEXT, ISNUMBER, ISODD, ISREF, ISTEXT, LOOKUP, NA, VALUE
Category Rounding
INT
Category Mathematical
ABS, ACOS, ACOSH, ASIN, ATAN, ATAN2, AVERAGE, AVERAGEA, COS, EVEN, EXP, LN, LOG10, MAX, MAXA, MIN, MINA, MOD, N, ODD, PI, POWER, SIN, SQRT, SUM, SUMA, VAR
Category Text
ARRAYRIGHT, ASC, CHAR, CLEAN, CODE, CONCATENATE, EXACT, FIND, FIXED, FIXED, LEFT, LEN, LOWER, MESSAGE, MID, PROPER, REPLACE, REPT, RIGHT, SEARCH, STRINGCOUNT, SUBSTITUTE, T, TEXT, TRIM, UNICHAR, UNICODE, UPPER, URLENCODE
Category Date/Time
DATE, DATEDIF, DATETIMEVALUE, DATEVALUE, DAY, DAYS, HOUR, MINUTE, MONTH, MONTHEND, NOW, PREVWEEKDAY, SECOND, TIME, TIMEVALUE, TODAY, WEEKDAY, YEAR, YESTERDAY
Category Logical
AND, FALSE, IF, IFNA, NOT, OR, TRUE, XOR
Category Database
BEGINSWITH, CONTAINS, ENDSWITH, EQUALS, IN, LIKE

关于linux - Excel函数的命令行执行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27843945/

相关文章:

linux - 用户程序还是内核模块?

python - 在 vim 中安装 YouCompleteMe 时遇到 python 问题

c++ - 在 python 线程中调用 TBB 'parallel_for'

excel - 在 Excel 中使用 COUNTIFS() 函数来匹配字符串

vba - Excel 未正确关闭 - 用户窗体挂起?

linux - sed 将 "_"、 "&"、 "$"分别替换为 "\_"、 "\&"、 "\$"

xml - 如何在xml中写入相对unix路径

linux - 从 Windows 到 Linux 服务器的 FTP 上传时附加的 CRLF 标签

Windows 批处理脚本 - For/L 不起作用 - 简单

java - 如何通过SXSSF保护Excel工作簿?