RNUMERIC( ) 函数

返回由 R 函数或脚本计算的数值。R 中的数据处理存在于 Analytics 的外部。

语法

RNUMERIC(rScript|rCode, 小数位 <,域|值 <,...n>>)

参数

名称 类型 描述
rScript | rCode

字符

R 脚本或一段要运行的 R 代码的完整或相对路径。

如果您直接输入 R 代码而不是使用外部文件,则不能在您的代码中使用引号字符,即使您对其进行转义:

  • 有效 'var <- "\"test\"" '
  • 无效 'var <- "\'test\'" '
小数位 数值 要在返回值中包括的小数位数。必须是正整数。
域 | 值 <,...n>

可选

字符

数值

日期时间

逻辑

要用作 R 脚本或代码片段的参数的域、表达式或字面量值的列表。

这些值被按照您指定它们的顺序传递给您调用的函数,并且您在 R 代码中使用 value1, value2 ... valueN 来引用它们。

您可以根据需要包括任意数量的参数,以满足 R 代码中的函数定义的需要。

说明

请使用 ALLTRIM() 函数删除字符输入内容中的任何前导或结尾空格:ALLTRIM(str)。要了解更多信息,请参考ALLTRIM( ) 函数

输出

数值。

示例

基本示例

使用 10 个小数位返回 100 (100.0000000000):

RNUMERIC("print(value1)", 10, 100)

高级示例

将 R 代码存储为变量

返回带有 10 个小数位的 100 (100.0000000000):

ASSIGN v_rcode = "print(value1)"
RNUMERIC(v_rcode, 10, 100)

写入到外部文件

执行简单的加法运算并且使用 R 中的 sink 函数将附加到函数的注释写入文件:

RNUMERIC("foo<-function(x,y){x+y};attr(foo, 'comment') <- 'foo performs simple addition';sink('c:/temp/result.txt');attributes(foo);sink(NULL);foo(value1,value2)",0, amt, gross)

备注

从 R 返回数据

调用 R 脚本时,请使用 source 函数并且将返回对象分配给变量。然后,您可以从返回对象中访问从您的 R 函数返回的值:

# 'a' 保存响应对象,a[[1]] 访问数据值
"a<-source('c:\\scripts\\r_scripts\\sample.r');a[[1]]"

R 日志文件

Analytics 将 R 语言消息记录到项目文件夹中的 aclrlang.log 文件。使用此日志文件可调试 R 错误。

提示

该日志文件位于 Analytics Exchange 解析作业的结果文件夹中。

在 AX 服务器上运行外部 R 脚本

如果您正在编写要在 AX 服务器上运行的分析应用程序并且想要使用外部 R 脚本,请:

  1. 将该文件作为相关文件与分析应用程序一同上传。
  2. 使用 FILE 解析标记标识文件。
  3. 使用相对路径 ./文件名.r 引用文件。

说明

使用相关文件可确保在用 Analytics Exchange 运行 R 时,TomEE 应用服务器账户具有足够的权限访问文件。

ACL 脚本指南 14.1