首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

R语言第二章数据处理⑥dplyr包(1)列选取目录选取列

========================================= 注意:所有代码都将作为管道的一部分呈现,即使它们中的任何一个都不是完整的管道。...选取列:基础部分 如果目的是选择其中几列,只需在select语句中添加列的名称即可。...添加它们的顺序将决定它们在output中的显示顺序。...甚至可以取消所有列,然后重新添加其中某列。下面的示例代码取消选择从name到awake的所有列,但重新添加列'conservation',即使它是取消选择的列的一部分。...根据预先确定的列名选择列 还有另一个选项可以避免连续重新输入列名:one_of()。 您可以预先设置列名,然后在select()语句中通过将它们包装在one_of()中或使用!!运算符来引用它们。

1.2K21
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    R语言第二章数据处理⑦dplyr包(2)列处理目录列名

    根据预先确定的列名选择列 还有另一个选项可以避免连续重新输入列名:one_of()。 您可以预先设置列名,然后在select()语句中通过将它们包装在one_of()中或使用!!运算符来引用它们。...如果你必须添加任何否定或参数,你必须将你的函数包装在funs()中,或者在重新创建函数之前添加波形符。 msleep %>% select_if(~!...按逻辑表达式选择列 实际上,select_if允许您根据任何逻辑函数进行选择,而不仅仅基于数据类型。 例如,可以选择平均值大于500的所有列。...为避免错误,您还必须仅选择数字列,您可以提前执行此操作以获得更简单的语法,也可以在同一行中执行。...n_distinct(),它计算可以在列中找到的不同值的数量。

    1.8K40

    dplyr中的行操作

    在tidyverse中,整洁数据一般都是每一行是一个观测,每一列是一个变量,基本上所有操作都是基于整洁的数据进行的,都是对某列做什么操作。...但有时候我们也需要对某行做一些操作,dplyr中现在提供了rowwise()函数快速执行对行的操作。...简介 library(dplyr, warn.conflicts = FALSE) “rowwise()和group_by()很像,本身不做任何操作,但是使用了rowwise之后,再和mutate()...(只是一个例子),不使用rowwise()函数,得到的结果是所有数据的均值,很明显不是想要的: df %>% mutate(m = mean(c(x, y, z))) ## # A tibble: 2...,那就是c_across,帮助你快速选择多列数据: rf %>% mutate(total = sum(c_across(w:z))) ## # A tibble: 6 × 6 ## # Rowwise

    1.3K30

    「r」dplyr 里的 join 与 base 里的 merge 存在差异

    相同的数据,不同的操作函数存在差异 在进行连接操作时,我们会发现 dplyr 的结果会报错!...r4 r1 r3 r2 #> 1 S1 S2 S2 S1 S1 #> 2 S2 S1 S1 S2 S2 看起来似乎有点不可理喻,但实际上上面我构造的数据集是有点特别的:前 2 个子集和第 3 个子集是没有可以连接的列的...本质上是 data.table 体格的泛型函数不支持类似基础包中的操作。 如何编写代码支持对上述数据集的连接操作?...一般工作情况下,不同的数据子集都存在可以连接的列,所以无论上述哪种方法都可以胜任工作。...检查 be_join 第一个子集的列与 to_join 存在共同列 等待循环结束 我们可以查看结果: to_join[, c("r1", "r2", "r3", "r4", "r5")] #> r1

    1.6K30

    R语言列筛选的方法--select

    我们知道,R语言学习,80%的时间都是在清洗数据,而选择合适的数据进行分析和处理也至关重要,如何选择合适的列进行分析,你知道几种方法? 如何优雅高效的选择合适的列,让我们一起来看一下吧。 1....数据描述 数据来源是我编写的R包learnasreml中的fm数据集。...使用R语言默认的方法:列选择 这一种,当然是简单粗暴的方法,想要哪一列,就把相关的列号提取出来,形成一个向量,进行操作即可。...5.2 放到环境变量中 「推荐的方法:」 r$> select = dplyr::select r$> a3 = a2 %>% select(ID,F1,y1,y2,y3) 推荐在载入包时,将下面代码放在开头...library(tidyverse) select = dplyr::select 6. 提取h开头的列 这里,用starts_with,会匹配开头为h的列。

    7.8K30

    R tips:使用!!来增加dplyr的可操作性

    R中代码的运行过程 在介绍!!运算符之前,有必要先了解一下R中的代码是如何运行的。 在R console中输入一个代码,R就会返回代码的结果。...这个瞬间的过程其实需要两个步骤和三个阶段: 代码 --解析-> 语句 --执行-> 结果 输入的是文本代码(code),R会首先解析成语句(R称之为expression),expression在R中是一个树状结构...执行expression(语句)即可获得结果,执行在R中叫做evaluation。 上述过程中,baseR中的函数parse可以进行解析工作,函数eval可以进行执行工作。...一个代码在R console中是直接运行到结束的,如果想要获得其中间态:语句,可以使用expr函数来捕获它。...辅助dplyr完成编程工作 上面的例子中,之所以group_var不起作用,是因为dplyr直接将group_var当做变量名,然后去mtcars中寻找名字叫做group_var的列,这肯定是会报错的。

    2.5K31

    基于R的竞争风险模型的列线图

    作者:科研猫 | 西红柿 责编:科研猫 | 馋猫 背景 将竞争风险模型的cmprsk包加载到R中,使用cuminc()函数和crr()函数可以进行考虑竞争风险事件生存数据的单变量分析和多变量分析。...以往推文我们已经详细描述了基于R语言的实现方法,这里不再赘述。那么,您如何看待竞争风险模型呢?如何绘制竞争风险模型的列线图?在这里,我们演示如何绘制基于R的列线图。...主要原因是,如果哑变量出现在列线图中,结果将难以解释清楚。 因此,应避免在列线图中使用哑变量。 regplot包中的regplot()函数可以绘制更多美观的列线图。...mstate包中crprep()函数的主要功能是创建此加权数据集,如下面的R代码所示。然后,我们可以使用coxph()函数拟合加权数据集的竞争风险模型,再将其给regplot()函数以绘制列线图。...R中的riskRegression包可以对基于竞争风险模型构建的预测模型进行进一步评估,例如计算C指数和绘制校准曲线等。

    4.2K20

    Mysql中的列类型

    Mysql中的列类型: 数字类型 字符串类型 布尔型 日期时间类型 数字类型: 1个字节=8比特,但数字里有一个比特用于符号占位 TINYINT 占用1个字节,表示范围:-128~127 SMALLINT...支持的范围是1000-01-01 ~ 9999-12-31 TIME 支持的范围是00:00:00 ~ 23:59:59 DATETIME 支持的范围是1000-01-01 00:00:00 ~ 9999...电话、手机号码:有格式要求 用户名:必须唯一 登录密码:密码不能为空字符串且长度不能少于N位 员工所在部门:可取值必须在部门表中存在过 主键约束: 列名 类型 PRIMARY KEY 声明为“...表中所有的记录行会自动按照主键列上的值进行排序。 一个表至多只能有一个主键列。 唯一约束: 列名 类型 UNIQUE 声明为“唯一”的列上不能出现重复值,但可以出现多个NULL值。...非空约束: 列名 类型 NOT NULL 声明为“非空”约束的列上不能出现NULL,但可以重复 检查约束对于Mysql不支持 默认值约束 列名 类型 Default 值 声明为“默认值”约束的列上没有值的将会默认采用默认设置的值

    6.4K20

    删除列中的 NULL 值

    图 2 输出的结果 先来分析图 1 是怎么变成图 2,图1 中的 tag1、tag2、tag3 三个字段都存在 NULL 值,且NULL值无处不在,而图2 里面的NULL只出现在这几个字段的末尾。...有一个思路:把每一列去掉 NULL 后单独拎出来作为一张独立的表,这个表只有两个字段,一个是序号,另一个是去 NULL 后的值。...比如 tag1 列变成 t1 表,tag2 列变成 t2 表,tag3 列变成 t3 表。...一个比较灵活的做法是对原表的数据做列转行,最后再通过行转列实现图2 的输出。具体的实现看下面的 SQL(我偷懒了,直接把原数据通过 SELECT 子句生成了)。...,按值在原表的列出现的顺序设置了序号,目的是维持同一列中的值的相对顺序不变。

    9.9K30

    R 语言 安装DESeq2,dplyr 包遇到报错的彻底解决方案

    一、问题 今天想使用 R 重新对数据进行差异表达分析,在安装DESeq2的时侯,遇到下面的报错: *Error: package or namespace load failed for ‘GenomeInfoDb...Error: 无法载入程辑包‘GenomeInfoDb’ In addition: Warning messages: 1: 程辑包‘DESeq2’是用R版本4.1.1 来建造的 2: 程辑包...‘GenomicRanges’是用R版本4.1.2 来建造的 3: 程辑包‘GenomeInfoDb’是用R版本4.1.2 来建造的 我现在使用的是笔记本电脑,我的台式电脑安装就没有遇到问题,不知道为什么...,于是开始搜索了一下教程,发现大家安装 DESeq2, dplyr 的时侯都会遇到**不存在叫 RCurl 这个名字的程辑包**的问题。...,就是直接安装二进制 binary 版本的R包。

    2.2K00

    Redis中的散列类型详解

    在Redis中,Hash是一种存储键值对的数据结构,它适用于存储对象的多个属性。Jedis作为Java开发者与Redis交互的工具,提供了丰富的API来操作Hash类型。...本文将深入介绍Jedis如何操作Redis中的Hash类型数据,通过生动的代码示例和详细的解释,助你轻松掌握Jedis中Hash的各种操作。Jedis中Hash的基本操作1....删除字段可以使用HDEL命令删除Hash类型数据中的一个或多个字段,在Jedis中,对应的方法是hdel:// 删除一个字段jedis.hdel("myHash", "field1");// 删除多个字段...中的Hash类型数据。...希望通过学习本文,你对Jedis中Hash的操作有了更深入的理解,并能够灵活运用在你的项目中。在实际开发中,充分发挥Jedis的优势,将有助于提升系统性能和代码质量。

    24920

    【R语言】R中的因子(factor)

    R中的因子用于存储不同类别的数据,可以用来对数据进行分组,例如人的性别有男和女两个类别,根据年龄可以将人分为未成年人和成年人,考试成绩可以分为优,良,中,差。...R 语言创建因子使用 factor() 函数,向量作为输入参数。...levels:指定各水平值, 不指定时由x的不同值来求得。 labels:水平的标签, 不指定时用各水平值的对应字符串。 exclude:排除的字符。 ordered:逻辑值,用于指定水平是否有序。...这个顺序也是有讲究的,一般是按字母顺序来排列。我们也可以按照自己的需要来排列因子的顺序。...关于这个参数后面我们还会给大家举个更实际的,跟临床数据相关的例子。 R中的因子使用还是更广泛的,例如做差异表达分析的时候我们可以根据因子将数据分成两组。

    3.4K30

    SQL中的行转列和列转行

    而在SQL面试中,一道出镜频率很高的题目就是行转列和列转行的问题,可以说这也是一道经典的SQL题目,本文就这一问题做以介绍分享。 ? 给定如下模拟数据集,这也是SQL领域经典的学生成绩表问题。...其基本的思路是这样的: 在长表的数据组织结构中,同一uid对应了多行,即每门课程一条记录,对应一组分数,而在宽表中需要将其变成同一uid下仅对应一行 在长表中,仅有一列记录了课程成绩,但在宽表中则每门课作为一列记录成绩...02 列转行:union 列转行是上述过程的逆过程,所以其思路也比较直观: 行记录由一行变为多行,列字段由多列变为单列; 一行变多行需要复制,列字段由多列变单列相当于是堆积的过程,其实也可以看做是复制;...,然后将该列命名为course;第二个用反引号包裹起来的课程名实际上是从宽表中引用这一列的取值,然后将其命名为score。...这实际上对应的一个知识点是:在SQL中字符串的引用用单引号(其实双引号也可以),而列字段名称的引用则是用反引号 上述用到了where条件过滤成绩为空值的记录,这实际是由于在原表中存在有空值的情况,如不加以过滤则在本例中最终查询记录有

    7.2K30
    领券