北京大学R语言教程(李东风)第11章:列表类型

R中列表(list)类型来保存不同类型的数据。
一个主要目的是提供R分析结果输出包装:
输出一个变量,
这个变量包括回归系数、预测值、残差、检验结果等等一系列不能放到规则形状数据结构中的内容。
实际上,数据框也是列表的一种,
但是数据框要求各列等长,
而列表不要求。

列表可以有多个元素,
但是与向量不同的是,
列表的不同元素的类型可以不同,
比如,
一个元素是数值型向量,
一个元素是字符串,
一个元素是标量,
一个元素是另一个列表。

定义列表用函数list(), 如

rec <- list(name="李明", age=30,
  scores=c(85, 76, 90))
rec
## $name
## [1] "李明"
## 
## $age
## [1] 30
## 
## $scores
## [1] 85 76 90

typeof()函数判断一个列表,
返回结果为list
可以用is.list()函数判断某个对象是否列表类型

为了生成元素为空的长度为n的列表,程序如:

11.2 列表元素访问

列表的一个元素也可以称为列表的一个“变量”,
单个列表元素必须用两重方括号格式访问,如

rec[[3]]
## [1] 85 76 90
rec[[3]][2]
## [1] 76
rec[["age"]]
## [1] 30

列表的单个元素也可以用$格式访问,如

如果使用单重方括号对列表取子集,
结果还是列表而不是列表元素,如

rec[3]
## $scores
## [1] 85 76 90
is.list(rec[3])
## [1] TRUE

列表一般都应该有元素名,
元素名可以看成是变量名,
列表中的每个元素看成一个变量。
names()函数查看和修改元素名。

names(rec)
## [1] "name"   "age"    "scores"
names(rec)[names(rec)=="scores"] <- "三科分数"
names(rec)
## [1] "name"     "age"      "三科分数"
rec[["三科分数"]]
## [1] 85 76 90

可以修改列表元素内容。

rec[["三科分数"]][2] <- 0
print(rec)
## $name
## [1] "李明"
## 
## $age
## [1] 30
## 
## $三科分数
## [1] 85  0 90

直接给列表不存在的元素名定义元素值就添加了新元素,
而且不同于使用向量,对于列表而言这是很正常的做法,比如

rec[["身高"]] <- 178
print(rec)
## $name
## [1] "李明"
## 
## $age
## [1] 30
## 
## $三科分数
## [1] 85  0 90
## 
## $身高
## [1] 178

把某个列表元素赋值为NULL就删掉这个元素。

rec[["age"]] <- NULL
print(rec)
## $name
## [1] "李明"
## 
## $三科分数
## [1] 85  0 90
## 
## $身高
## [1] 178

list()函数中允许定义元素为NULL,这样的元素是存在的,如:

li <- list(a=120, b="F", c=NULL); li
## $a
## [1] 120
## 
## $b
## [1] "F"
## 
## $c
## NULL

但是,要把已经存在的元素修改为NULL值而不是删除此元素,
或者给列表增加一个取值为NULL的元素,
这时需要用单重的方括号取子集,
这样的子集会保持其列表类型,
给这样的子列表赋值为list(NULL),如:

li["b"] <- list(NULL)
li["d"] <- list(NULL)
li
## $a
## [1] 120
## 
## $b
## NULL
## 
## $c
## NULL
## 
## $d
## NULL

11.3 列表类型转换

as.list()把一个其它类型的对象转换成列表;
unlist()函数把列表转换成基本向量。如

li1 <- as.list(1:3)
li1
## [[1]]
## [1] 1
## 
## [[2]]
## [1] 2
## 
## [[3]]
## [1] 3
li2 <- list(x=1, y=c(2,3))
unlist(li2)
##  x y1 y2 
##  1  2  3

11.4 连接列表

两个列表可以用c连接成一个列表,
如:

li1 <- list(1:2)
li2 <- list(11:12)
li <- c(li1, li2)
li
## [[1]]
## [1] 1 2
## 
## [[2]]
## [1] 11 12

如下的做法没有达到目的:

li <- list()
li <- c(li, 1:3)
li <- c(li, 11:13)
li
## [[1]]
## [1] 1
## 
## [[2]]
## [1] 2
## 
## [[3]]
## [1] 3
## 
## [[4]]
## [1] 11
## 
## [[5]]
## [1] 12
## 
## [[6]]
## [1] 13

需要改为:

li <- list()
li <- c(li, list(1:3))
li <- c(li, list(11:13))
li
## [[1]]
## [1] 1 2 3
## 
## [[2]]
## [1] 11 12 13

11.5 返回列表的函数示例–strsplit()

strsplit()输入一个字符型向量并指定一个分隔符,
返回一个项数与字符型向量元素个数相同的列表,
列表每项对应于字符型向量中一个元素的拆分结果。

x <- c("10, 8, 7", "5, 2, 2", "3, 7, 8", "8, 8, 9")
res <- strsplit(x, ","); res
## [[1]]
## [1] "10" " 8" " 7"
## 
## [[2]]
## [1] "5"  " 2" " 2"
## 
## [[3]]
## [1] "3"  " 7" " 8"
## 
## [[4]]
## [1] "8"  " 8" " 9"

为了把拆分结果进一步转换成一个数值型矩阵,
可以使用sapply()函数如下:

t(sapply(res, as.numeric))
##      [,1] [,2] [,3]
## [1,]   10    8    7
## [2,]    5    2    2
## [3,]    3    7    8
## [4,]    8    8    9

sapply()函数是apply类函数之一,
稍后再详细进行讲解。

韭菜热线原创版权所有,发布者:风生水起,转载请注明出处:https://www.9crx.com/77953.html

(0)
打赏
风生水起的头像风生水起普通用户
上一篇 2023年10月30日 01:56
下一篇 2023年10月31日 00:16

相关推荐

  • MPT之父马科维茨始终深知模型的局限性

    “你甚至可能会说哈里·马科维茨对历史相关性的预测能力持怀疑态度,”桑德·格伯写道。 哈里·马科维茨和桑德·格伯坐在一起。马科维茨拥有约翰·冯·诺依曼理论奖,这是他最珍视的奖项。格伯获得了诺贝尔奖。(礼貌照片) 无数投资者,从养老金领取者、医院捐赠基金到普通个人,都因为最近去世、享年 95 岁的诺贝尔经济学奖得主哈里·马科维茨 (Harry Markowitz…

    2023年8月14日
    31500
  • 美联储能否实现软着陆?

    当前的经济环境令人困惑。就业增长强劲,但知名公司裁员的报道却随处可见。收益率曲线倒挂,暗示经济衰退即将来临,但股市却处于或接近历史高位。 我们如何看待这些相互矛盾的信号?经济能否实现预期的“软着陆”——经济增长放缓或温和衰退?还是“硬着陆”和“常规甚至严重衰退”不可避免? 只要美联储从沉睡中醒来,并且某些其他缓解因素持续存在,我相信我们仍然可以坚持下去。但许…

    2024年4月27日
    16400
  • 医疗保健股:2024 年走势会更加平稳吗?

    在最近表现不佳之后,随着创新的兴起和后新冠疫情重置的结束,医疗保健行业正以压缩的估值进入新的一年。投资组合经理安迪·阿克 (Andy Acker) 和丹·莱昂斯 (Dan Lyons) 表示,这应该会带来积极的前景 要点: 由于新冠疫情销售下降、债券收益率上升以及新的减肥疗法造成干扰,医疗保健行业正在经历表现不佳的一年。 因此,许多医疗保健估值已经收缩,这可…

    2023年12月20日
    17600
  • 波动率鸡尾酒

    波动性鸡尾酒 思考思考…… “不被障碍压倒、不被障碍挫败或不被障碍困扰是一回事。很少有人能做到这一点。但当你控制了自己的情绪,能够客观地看待问题并坚定地站稳脚跟后,下一步就有可能了:思维上的转变,这样你就不会只关注障碍,而是关注其中的机会。” ——瑞安·霍利迪 (Ryan Holiday),《障碍就是道路》 30,000 英尺高空景观 综合起来 回顾过去的 …

    2024年10月9日
    9000
  • 2023年美国职场这些职业的薪资增幅最高,而其他职业则落后

    每年加薪可以帮助工人跟上经济中不断上涨的商品和服务成本。但当物价上涨速度快于工资上涨速度时,加薪最终感觉更像是减薪。 过去几年,通货膨胀使工资增长相形见绌,许多工人就是这种情况。虽然平均收入在此期间增长了 5%,但通货膨胀率却超过了 8.58%。 考虑到这一点,通过分析美国劳工统计局 751 个职业的工资数据,着手了解哪些职业在这 12 个月期间工资增幅最高…

    2023年8月23日
    40300

发表回复

登录后才能评论
客服
客服
关注订阅号
关注订阅号
分享本页
返回顶部