R语言【base】——data.frame():创建数据框,紧耦合的变量集合,它们共享矩阵和列表的许多属性,被大多数R建模软件用作基本数据结构。

本文主要是介绍R语言【base】——data.frame():创建数据框,紧耦合的变量集合,它们共享矩阵和列表的许多属性,被大多数R建模软件用作基本数据结构。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Package base version 4.2.0


Description

创建数据框(data frame),紧耦合的变量集合,它们共享矩阵和列表的许多属性,被大多数R建模软件用作基本数据结构。

数据框:一种在统计分析和数据处理中常用的数据结构,由行和列组成,类似于电子表格。


Usage

data.frame(..., row.names = NULL, check.rows = FALSE,check.names = TRUE, fix.empty.names = TRUE,stringsAsFactors = FALSE)

Arguments

参数【...】:这些参数的形式是 value 或 tag = value。组件名称是基于标签(如果存在)或解析参数本身创建的。

参数【row.names】:NULL 或单个整数或字符串,指定要用作行名的列,或一个字符或整数向量,为数据框提供行名。

参数【check.rows】:如果为 TRUE,则检查行长度与名称的一致性。

参数【check.names】:逻辑值。如果为TRUE,则检查数据框中的变量名,以确保它们是语法上有效的变量名,并且不重复。如有必要,可以对它们进行调整(通过make.names)。

参数【fix.empty.names】:逻辑值,指示“未命名”的参数(在没有被 someName = arg 正式命名)是否获得自动构造的名称,或者更确切地说是 “”。即使 check.names 为 FALSE,如果应该保留 “”名称,也需要设置为 FASLE。

参数【stringsAsFactors】:逻辑值:应该将字符向量转换为因子吗?“factory-fresh”的默认值以前为TRUE,但在R 4.0.0 中已更改为FALSE。


Details

数据框是给定类“data.frame”的具有相同行数且具有唯一行名的变量列表。如果不包含变量,则行名决定行数。

列名应该是非空的,尝试使用空名称将产生不支持的结果。允许使用重复的列名,但是您需要对data.frame使用check.names = FALSE来生成这样的数据帧。然而,并不是所有对数据帧的操作都会保留重复的列名:例如,类似矩阵的子集将强制结果中的列名是唯一的。

data.frame通过调用as.data.frame(optional = TRUE)将它的每个参数转换为一个数据帧。由于这是一个泛型函数,因此可以编写方法来根据其类更改参数的行为:R提供了许多这样的方法。传递给data.frame的字符变量如果没有I保护,并且参数stringsAsFactors为真,则转换为因子列。如果将列表或数据帧或矩阵传递给data.frame,则好像每个组件或列都作为单独的参数传递(由I保护的矩阵除外)。

传递给data.frame的对象应该具有相同的行数,但是原子向量(参见is.vector)、因子和受I保护的字符向量将在必要时被循环使用整次(包括作为列表参数的元素)。

如果在对data.frame的调用中没有提供行名,则从具有合适名称的第一个组件中获取行名,例如具有行名或数据帧的命名向量或矩阵。(如果该组件随后被回收,则这些名称将被丢弃并发出警告。)如果row.names作为NULL提供或没有找到合适的组件,则行名是从1开始的整数序列(并且这样的行名被认为是“自动的”,而不是由as.matrix保留)。

如果提供的行名长度为1,并且数据帧只有一行,则使用row.names来指定行名,而不是列名(通过名称或数字)。

从不受I保护的向量输入中删除名称。


Value

一种数据框架,一种类似矩阵的结构,其列可以是不同的类型(数字、逻辑、因子和字符等)。

如何创建数据帧的名称是复杂的,本段的其余部分只是基本的故事。如果参数都是命名的简单对象(不是列表、数据帧矩阵),则参数名给出列名。对于一个未命名的简单参数,使用参数的离去版本作为名称(去掉了封闭的I(…))。对于具有多个命名列的命名矩阵/列表/数据帧参数,列的名称是参数的名称后跟一个点和参数内的列名:如果参数未命名,则使用参数的列名。对于包含单个列的已命名或未命名的矩阵/列表/数据帧参数,结果中的列名就是参数中的列名。最后,将这些名称调整为唯一且在语法上有效,除非check.names = FALSE。


Example

L3 <- LETTERS[1:3]
char <- sample(L3, 10, replace = TRUE)
(d <- data.frame(x = 1, y = 1:10, char = char))
   x  y char
1  1  1    A
2  1  2    A
3  1  3    C
4  1  4    B
5  1  5    B
6  1  6    A
7  1  7    A
8  1  8    A
9  1  9    A
10 1 10    B
data.frame(1, 1:10, sample(L3, 10, replace = TRUE))
   X1 X1.10 sample.L3..10..replace...TRUE.
1   1     1                              B
2   1     2                              C
3   1     3                              C
4   1     4                              B
5   1     5                              A
6   1     6                              A
7   1     7                              B
8   1     8                              A
9   1     9                              B
10  1    10                              C
is.data.frame(d)
[1] TRUE
(dd <- data.frame(d, fac = letters[1:10], stringsAsFactors = TRUE))
   x  y char fac
1  1  1    A   a
2  1  2    A   b
3  1  3    C   c
4  1  4    B   d
5  1  5    B   e
6  1  6    A   f
7  1  7    A   g
8  1  8    A   h
9  1  9    A   i
10 1 10    B   j
rbind(class = sapply(dd, class), mode = sapply(dd, mode))
      x         y         char        fac      
class "numeric" "integer" "character" "factor" 
mode  "numeric" "numeric" "character" "numeric"
stopifnot(1:10 == row.names(d)) 
(d0  <- d[, FALSE]) 
data frame with 0 columns and 10 rows
(d.0 <- d[FALSE, ]) 
[1] x    y    char
<0 行> (或0-长度的row.names)
(d00 <- d0[FALSE, ])
data frame with 0 columns and 0 rows

这篇关于R语言【base】——data.frame():创建数据框,紧耦合的变量集合,它们共享矩阵和列表的许多属性,被大多数R建模软件用作基本数据结构。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/730806

相关文章

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

Hadoop集群数据均衡之磁盘间数据均衡

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x新特性) plan后面带的节点的名字必须是已经存在的,并且是需要均衡的节点。 如果节点不存在,会报如下错误: 如果节点只有一个硬盘的话,不会创建均衡计划: (1)生成均衡计划 hdfs diskbalancer -plan hadoop102 (2)执行均衡计划 hd

基本知识点

1、c++的输入加上ios::sync_with_stdio(false);  等价于 c的输入,读取速度会加快(但是在字符串的题里面和容易出现问题) 2、lower_bound()和upper_bound() iterator lower_bound( const key_type &key ): 返回一个迭代器,指向键值>= key的第一个元素。 iterator upper_bou

变量与命名

引言         在前两个课时中,我们已经了解了 Python 程序的基本结构,学习了如何正确地使用缩进来组织代码,并且知道了注释的重要性。现在我们将进一步深入到 Python 编程的核心——变量与命名。变量是我们存储数据的主要方式,而合理的命名则有助于提高代码的可读性和可维护性。 变量的概念与使用         在 Python 中,变量是一种用来存储数据值的标识符。创建变量很简单,

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi