前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >「R」从公式中提取组分

「R」从公式中提取组分

作者头像
王诗翔呀
发布2020-07-02 21:30:18
发布2020-07-02 21:30:18
40200
代码可运行
举报
文章被收录于专栏:优雅R优雅R
运行总次数:0
代码可运行

问题

你想要抽离公式的一部分用来使用。

方案

你可以把公式对象当作列表看待,使用[[操作符对其组分进行操作。

代码语言:javascript
代码运行次数:0
运行
复制
f <- y ~ x1 + x2

# 观察f结构
str(f)
#> Class 'formula'  language y ~ x1 + x2
#>   ..- attr(*, ".Environment")=<environment: 0x1e46710>

# 获得每一部分
f[[1]]
#> `~`
f[[2]]
#> y
f[[3]]
#> x1 + x2

# 转换为列表观察
as.list(f)
#> [[1]]
#> `~`
#>
#> [[2]]
#> y
#>
#> [[3]]
#> x1 + x2
#>
#> <environment: 0x1e46710>

如果公式左边没有任何东西,那么列表只有两个元素:

代码语言:javascript
代码运行次数:0
运行
复制
f2 <- ~ x1 + x2
as.list(f2)
#> [[1]]
#> `~`
#>
#> [[2]]
#> x1 + x2
#>
#> <environment: 0x1e46710>

公式的每一个元素都是一个符号或者语言对象(包含多个符号):

代码语言:javascript
代码运行次数:0
运行
复制
str(f[[1]])
#>  symbol ~
str(f[[2]])
#>  symbol y
str(f[[3]])
#>  language x1 + x2

# Look at parts of the langage object
str(f[[3]][[1]])
#>  symbol +
str(f[[3]][[2]])
#>  symbol x1
str(f[[3]][[3]])
#>  symbol x2

你可以使用as.character()deparse()函数将它们转为字符串。deparse()函数可以返回一个看起来更为自然的结果:

代码语言:javascript
代码运行次数:0
运行
复制
as.character(f[[1]])
#> [1] "~"
as.character(f[[2]])
#> [1] "y"

# The language object gets coerced into a string that represents the parse tree:
as.character(f[[3]])
#> [1] "+"  "x1" "x2"

# You can use deparse() to get a more natural looking string
deparse(f[[3]])
#> [1] "x1 + x2"
deparse(f)
#> [1] "y ~ x1 + x2"

公式对象也会捕捉调用它的环境,比如我们在运行str(f)命令时看到的那样。如果要抽取它,可以使用environment()函数:

代码语言:javascript
代码运行次数:0
运行
复制
environment(f)
#> <environment: 0x1e46710>
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-04-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 优雅R 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 问题
  • 方案
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档