R语言【base】——apply():在数组边距上应用函数

Package base version 4.2.0


Description

返回通过将函数应用于数组或矩阵的边距而获得的向量或数组或值列表。


Usage

R 复制代码
apply(X, MARGIN, FUN, ..., simplify = TRUE)

Arguments

参数【X】:一个数组,包括一个矩阵。

参数【MARGIN】:一个给出下标的向量,函数将作用于这个下标。例如,对于矩阵,1 表示行,2 表示列,c(1,2) 表示行和列。其中**参数【X】**具有命名 dimname,它可以是选择维度名称的字符向量。

参数【FUN】 :要应用的函数。对于 +、**%*%**等函数,函数名必须用反引号或引号括起来。

参数【...】:**参数【FUN】**的可选参数。

参数【simplify】:说明结果是否应尽可能简化的逻辑值。


Details

如果**参数【X】**不是一个数组,而是一个具有非空 dim 值 (例如数据帧) 的类的对象,则 apply 尝试通过 as.array 将其强制转换为一个数组。如果它是二维的 (例如,一个数据帧) 则通过 as.matrix 转换。

参数【FUN】 是通过调用 match 找到的。通常是一个函数或一个符号 (例如,一个反引号的名称),或者一个字符串,指定要从要应用的调用环境中搜索的函数。

参数【...】的参数不能与任何其他参数具有相同的名称,并且可能需要注意避免与参数【MARGIN】参数【FUN】 部分匹配。在通用代码中,最好将前三个参数命名:这既避免了与参数【MARGIN】参数【FUN】 的部分匹配,又确保了在通过参数【...】传递名为参数【X】、**参数【MARGIN】参数【FUN】**的参数时给出一个合理的错误消息。


Value

如果每次调用参数【FUN】 返回一个长度为 n 的向量,且参数【simplify】TRUE,则apply 返回一个维度为 c(n, dim(X)MARGIN) 的数组 (如果n > 1)。如果 n 等于 1, apply 返回一个向量,如果**参数【MARGIN】**长度为 1 ,则返回一个维度 dim(X)MARGIN 的数组。如果 n0 ,则结果长度为 0,但不一定是 "正确" 的维度。

如果调用参数【FUN】 返回不同长度的向量,或者如果**参数【simplify】**为 FALSE, apply返回一个长度为 prod(dim(X)MARGIN) 的列表,如果长度大于 1 ,则 dim 设置为 参数【MARGIN】

在所有情况下,结果都由 as.vector 强制执行。在设置维度之前,将向量转换为基本向量类型之一,这样 (例如) 因子结果将被强制转换为字符数组。

相关推荐
弹简特8 分钟前
【Java项目-轻聊】08-用户管理模块-实现获取用户信息+头像上传+显示头像
java·开发语言·springboot
vickycheung312 分钟前
RK182X 如何在 RK3588 上进行应用测试
开发语言·php
半壶清水1 小时前
用python脚本加html自建的书法字典
开发语言·python·html
凯瑟琳.奥古斯特1 小时前
力扣1003题C++解法详解
开发语言·c++·算法·leetcode·职场和发展
myenjoy_11 小时前
Python + Snap7 实现西门子 S7-1200/1500 数据采集
开发语言·python
c238561 小时前
C++11final与override6、智能指针
开发语言·c++
*neverGiveUp*1 小时前
初步了解Django框架
开发语言·python·django
Java_2017_csdn1 小时前
在 Java 中,MessageFormat.format() 和 String.format() 函数对比?
java·开发语言·前端·数据库
绛洞花主敏明1 小时前
Go操作xorm中间表多对多关联实战
开发语言·后端·golang
Jun6261 小时前
QT(4)-EXCEL操作
开发语言·qt·excel