美文网首页
R语言边学边记7-apply,lapply,sapply函数

R语言边学边记7-apply,lapply,sapply函数

作者: Jerry_5543 | 来源:发表于2019-03-26 23:20 被阅读0次

    > #apply函数

    > #1,对矩阵的行或者列使用函数

    > m1<-matrix(1:20,nrow = 4)

    > m1

         [,1] [,2] [,3] [,4] [,5]

    [1,]    1    5    9   13   17

    [2,]    2    6   10   14   18

    [3,]    3    7   11   15   19

    [4,]    4    8   12   16   20

    > #求矩阵和

    > apply(m1,MARGIN = 1,sum)#求m1每一行的和

    [1] 45 50 55 60

    > apply(m1,MARGIN = 2,sum)#求矩阵每一列的和

    [1] 10 26 42 58 74

    > #fun(sum的位置,为fun函数,功能)也可以是自定义函数

    > #大括号不是中括号

    > f1<-function(x){

    +   x*100

    + }#*为乘法函数,不是等号

    > apply(m1,MARGIN = 1,f1)#自定义f1为扩大一百倍,按照行排列

         [,1] [,2] [,3] [,4]

    [1,]  100  200  300  400

    [2,]  500  600  700  800

    [3,]  900 1000 1100 1200

    [4,] 1300 1400 1500 1600

    [5,] 1700 1800 1900 2000

    > m1

         [,1] [,2] [,3] [,4] [,5]

    [1,]    1    5    9   13   17

    [2,]    2    6   10   14   18

    [3,]    3    7   11   15   19

    [4,]    4    8   12   16   20

    > #2.对数组的各个维度使用函数,以三维数组为例

    > #定义数组各个维度的名称,以及创建一个三维数组a1

    > xname<-c("x1","x2")

    > yname<-c("y1","y2","y3")

    > zname<-c("z1","z2","z3","z4")

    > a1<-array(1:24,c(2,3,4),dimnames = list(xname,yname,zname))#数组2行3列4个矩阵,再命名

    > #list为列表

    > a1

    , , z1

       y1 y2 y3

    x1  1  3  5

    x2  2  4  6

    , , z2

       y1 y2 y3

    x1  7  9 11

    x2  8 10 12

    , , z3

       y1 y2 y3

    x1 13 15 17

    x2 14 16 18

    , , z4

       y1 y2 y3

    x1 19 21 23

    x2 20 22 24

    > #求出a1的各个维度的和

    > apply(a1,1,sum)

     x1  x2 

    144 156 

    > apply(a1,2,sum)

     y1  y2  y3 

     84 100 116 

    > apply(a1,3,sum)

     z1  z2  z3  z4 

     21  57  93 129 

    > #data.frame也可以使用apply函数,apply函数会自动将数据框转换矩阵

    > #但是前提是数据框中各列的数据类型必须是数值型,

    > #如果是数值型,将会出错

    > d1<-c(1,2,3,4)

    > d2<-c(10,20,30,40)

    > df<-data.frame(d1,d2)

    > df

      d1 d2

    1  1 10

    2  2 20

    3  3 30

    4  4 40

    > apply(df,2,sum)#列求和

     d1  d2 

     10 100 

    > apply(df,1,sum)#行求和

    [1] 11 22 33 44

    > d1<-c("c",2,3,4)

    > d2<-c(10,20,30,40)

    > df<-data.frame(d1,d2)

    > df

      d1 d2

    1  c 10

    2  2 20

    3  3 30

    4  4 40

    > apply(df,1,sum)#出错

    Error in FUN(newX[, i], ...) : invalid 'type' (character) of argument

    > #lapply函数

    > #对列表使用函数,返回值为列表

    > l1<-list(v<-1:10,m<-matrix(1:20,4))

    > l1

    [[1]]

     [1]  1  2  3  4  5  6  7  8  9 10

    [[2]]

         [,1] [,2] [,3] [,4] [,5]

    [1,]    1    5    9   13   17

    [2,]    2    6   10   14   18

    [3,]    3    7   11   15   19

    [4,]    4    8   12   16   20

    > #求列表中各元素的和

    > lapply(l1,sum)

    [[1]]

    [1] 55

    [[2]]

    [1] 210

    > #sapply,输出的结果是向量,lapply输出结果是列表

    > l1

    [[1]]

     [1]  1  2  3  4  5  6  7  8  9 10

    [[2]]

         [,1] [,2] [,3] [,4] [,5]

    [1,]    1    5    9   13   17

    [2,]    2    6   10   14   18

    [3,]    3    7   11   15   19

    [4,]    4    8   12   16   20

    > sapply(l1,sum)

    [1]  55 210

    相关文章

      网友评论

          本文标题:R语言边学边记7-apply,lapply,sapply函数

          本文链接:https://www.haomeiwen.com/subject/bjbovqtx.html