1 list 本质上也是一种向量

1.1普通的向量是原子型(atomic)向量,就是说,向量的元素已经是最小的不可再分的了。

      而list属于“递归型”(recursive)向量。

1.2 list可以包含不同的数据类型。(显然普通的向量是不行的)

2 创建list

2.1

#method 1
> j<-list(name="Joe",salary=10000,union=T)
> j
$name
[1] "Joe"

$salary
[1] 10000

$union
[1] TRUE
#method 2: without  column name
> j<-list("Joe",10000,T)
> j
[[1]]
[1] "Joe"

[[2]]
[1] 10000

[[3]]
[1] TRUE

# method 3: create it like a special vector
> z<-vector(mode="list")
> z[['v1']]<-3
> z
$v1
[1] 3



2.2 在引用的时候,标签的名字可以简写,只要写出前几个字母,且不引起歧义,R都能够识别。

2.3 在创建时,建议为每列命名,这样能使程序更加清楚明了,不易出错。


3 列表索引与增删改查

列表索引虽然和向量相似,但是还是有很大的不同,因此要非常注意。

3.1 索引方法

#method 1
> j$salary
[1] 1e+04 1e+06
> j$salary[1]
[1] 10000

#method 2
> j[[2]]
[1] 1e+04 1e+06
> j[[2]][1]
[1] 10000

#method 3
> j[["salary"]]
[1] 1e+04 1e+06
> j[["salary"]][1]
[1] 10000

#method 4
> j[1]
$name
[1] "Joe" "fan"

> class(j[1])
[1] "list"

> j[1][1]
$name
[1] "Joe" "fan"

3.3.1 注意:前三种方法,取得的值都是各自数据类型的向量,我们取出了salary这一列,如果我们用class查看,其结果是numeric;而最后一种方法,取得的是list!

3.3.2 一定要区分[[ ]]和[ ] 这两种操作符。前者(即[[ ]]),取出的是一个普通的向量,其数据类型是向量中元素的数据类型;而后者(即[]),取出的依然是list,千万不要搞混

3.3.3 总结一下,在R中,对提取list中的指有共有两大类方法,其区别就在于取出的值是list还是其本身的类型

大类一:取出的值是其数据类型本身

>j$salary
>j[["salary"]]
>j[[1]]



大类二:取出的是列表

>j["salary"]
>j[1]



3.2 增加

列表和向量不同,我们可以向列表中添加一个值。

#method 1
> z<-list(a="abc",b=12)
> z
$a
[1] "abc"

$b
[1] 12

> z$c<-c("sailing","car") #添加
> z
$a
[1] "abc"

$b
[1] 12

$c
[1] "sailing" "car"    

#method 2

> z[[4]]<-c(29,28) #注意,要用双中括号
> z
$a
[1] "abc"

$b
[1] 12

$c
[1] "sailing" "car"    

[[4]]
[1] 29 28



3.3 删除


> z
$a
[1] "abc"

$b
[1] 12

$c
[1] "sailing" "car"    

[[4]]
[1] 29 28

#method 1
> z[4]<-NULL #删除,单中括号和双中括号都可以。
> z
$a
[1] "abc"

$b
[1] 12

$c
[1] "sailing" "car"    

> z
$a
[1] "abc"

$b
[1] 12

$c
[1] "sailing" "car"    

<pre name="code" class="plain">#method 2

> z$a<-NULL #删除> z$b[1] 12$c[1] "sailing" "car"



3.3.1 显然,这两种方法没有本质区别,都是将找到的列赋予NULL;区别并不在于如何删除,而是索引方法不同。

3.3.2 当为一个列设定了NULL之后,R会自动的索引序号,被删除列后面的索引均会自动减去1。


3.4 将两个list拼接起来

> z<-c(list('abc',2,T),list(4))
> z
[[1]]
[1] "abc"

[[2]]
[1] 2

[[3]]
[1] TRUE

[[4]]
[1] 4




4 常用操作

4.1 length() 查看list的列数

4.2 unlist() 将list转化为向量。如果list中存在着不同的存储模式,R将会自动的将不同的存储模式转化为一种,R会选择能够最大的保持他们共同特征的类型。

4.3 unname(j)  或者是 names(j)<-NULL 都可以将list j的列名去除

4.4 names(j) 查看list j的列名

4.5 lapply(list,function)   (list apply) 同矩阵的apply类似,对list中的每个组建应用function函数。


5 递归性列表

列表的递归性是指:列表中的组建依旧可以是列表。


> a<-list("a","afd","dfa")
> b<-list(1,2,3,4,5)
> c<-list(a,b)
> c
[[1]]
[[1]][[1]]
[1] "a"

[[1]][[2]]
[1] "afd"

[[1]][[3]]
[1] "dfa"


[[2]]
[[2]][[1]]
[1] 1

[[2]][[2]]
[1] 2

[[2]][[3]]
[1] 3

[[2]][[4]]
[1] 4

[[2]][[5]]
[1] 5