「Debug R」有些你认为的报错不是报错(error),是警告(warnnings)

2024-06-23 20:38

本文主要是介绍「Debug R」有些你认为的报错不是报错(error),是警告(warnnings),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在学员答疑群里看到这样一条提问:

2013053-9288435b545d02d2.png
提问

对于这种提问,我只想给出一张深藏已久的图作为回复。

2013053-6c4311f448a94ec1.png
警告和报错

在「Debug R」报错"unable to find an inherited method for function"是如何产生的文章中,我提到一个好的搜索引擎是解决问题的重要因素,于是他也在提问中也提到自己用了谷歌。

虽然搜索引擎能够帮助我们处理大部分问题,相当于人的外脑,但是有一个功能是搜索引擎还无法做到,就是“思考”。他这个不算报错的“报错”就需要一定的思考,让我们先对警告信息进行翻译,

警告信息: 在tibble设置行名已经弃用(deprecated)

这里的关键字是弃用(deprecated), 在软件迭代过程中,作者会慢慢把一些功能取消掉,这些被取消的功能在被调用时就会有该提示。从这个信息中,我可以推断出,提出这个问题的人在用tidyverse系列的R包,并且在使用过程中将 原本的 data.frame 数据结构转成了 tibble 数据结构。

现在,让我们来复现这个问题(为了区分输出信息和代码,R代码部分用>提示,运行时需要删掉)

> library(tibble)
> mtcars <- as_tibble(mtcars)
> rownames(mtcars) <- paste0("Car_", seq(1,nrow(mtcars)))Warning message:
Setting row names on a tibble is deprecated> head(mtcars, n=2)
# A tibble: 2 x 11mpg   cyl  disp    hp  drat    wt  qsec    vs    am  gear  carb<dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl>
1    21     6   160   110   3.9  2.62  16.5     0     1     4     4
2    21     6   160   110   3.9  2.88  17.0     0     1     4     4

那么问题如何解决呢?有两种方式, 第一种是将 tibble 用 as.data.frame转回成数据框结构,但我不推荐,因为这违背了tidyverse的设计思想,而且后续你还在调用dplyr的函数还会遇到行名丢失 的问题

> mtcars <- as.data.frame(mtcars)
> rownames(mtcars) <- paste0("Car_", seq(1,nrow(mtcars)))
> head(mtcars, n=2)mpg cyl disp  hp drat    wt  qsec vs am gear carb
Car_1  21   6  160 110  3.9 2.620 16.46  0  1    4    4
Car_2  21   6  160 110  3.9 2.875 17.02  0  1    4    4

另一种方法,新增一列存放行名

> library(tibble)
> mtcars <- as_tibble(mtcars)
> mtcars$rownames <- paste0("Car_", seq(1,nrow(mtcars)))
> head(mtcars, n=2)
# A tibble: 2 x 12mpg   cyl  disp    hp  drat    wt  qsec    vs    am  gear  carb rownames<dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <dbl> <chr>   
1    21     6   160   110   3.9  2.62  16.5     0     1     4     4 Car_1   
2    21     6   160   110   3.9  2.88  17.0     0     1     4     4 Car_2 

这种解决方法才是tidyverse系列包所喜欢的样子。

hoptop -- 可能是中国在现场处理过R语言报错最多的人

这篇关于「Debug R」有些你认为的报错不是报错(error),是警告(warnnings)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

#error用法

/* *检查编译此源文件的编译器是不是C++编译器 *如果使用的是C语言编译器则执行#error命令 *如果使用的是 C++ 编译器则跳过#error命令 */ #ifndef __cplusplus #error 亲,您当前使用的不是C++编译器噢! #endif #include <stdio.h> int main() {

警告,恶意域名疯狂外联,原因竟然是……

前言 &nbsp;&nbsp; 在某个风和日丽的下午,突然收到客户那边运维发过来的消息说我司的DTA设备在疯狂告警,说存在恶意域名外联,我急忙背上小背包前往客户现场,经过与客户协同排查,最终确定该事件为一起挖矿病毒引起的恶意域名外联事件。(因客户信息保密且为了保证文章逻辑完整性,部分截图为后期追加图) 事件分析 一看域名地址donate.v2.xmrig.com

yum install 失败报错`XZ_5.1.2alpha' not found (required by /lib64/librpmio.so.3)

/export/env/py3.6/lib/liblzma.so.5: version `XZ_5.1.2alpha' not found (required by /lib64/librpmio.so.3)   到/export/env/py3.6/lib cp /lib64/liblzma.so.5.2.2 . sudo ln -s -f liblzma.so.5.2.2 liblzm

brew install opencv@2 时报错 Error: Can't create update lock in /usr/local/var/homebrew/locks!

解决方案,报错里已经说明了: 我的解决方案: sudo chown -R "$USER":admin /usr/local   stackoverflow上的答案 I was able to solve the problem by using chown on the folder: sudo chown -R "$USER":admin /usr/local Also you'

BD错误集锦8——在集成Spring MVC + MyBtis编写mapper文件时需要注意格式 You have an error in your SQL syntax

报错的文件 <?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="com.yuan.dao.YuanUserDao"><!

BD错误集锦6——【IDEA报错】tomcat server功能无效,报错Java EE: EJB, JPA, Servlets

在网上查找原因,发现是非法关闭IDEA导致的。 Open Settings | Plugns and enable it. 在设置中enable JAVA EE和tomcat server即可。 参考: https://stackoverflow.com/questions/43607642/intellij-idea-plugin-errorproblems-found-loadin

BD错误集锦3——ERROR: Can't get master address from ZooKeeper; znode data == null

hbase集群没启动,傻子!   启动集群 [s233 s234 s235]启动zk集群 $>zkServer.sh start $>zkServer.sh status   [s233] 启动dfs系统 $>start-dfs.sh 如果s237 namenode启动失败,则 [s237] $>hadoop-daemon.sh start namenode [s233]启动yarn集群

BD错误集锦1——[Hive]ERROR StatusLogger No log4j2 configuration file found. Using default configuration:

错误描述:在使用IDEA进行jdbc方式连接到hive数据仓库时,出现以下错误:                ERROR StatusLogger No log4j2 configuration file found. 问题原因:缺少log4j2.xml文件   <?xml version="1.0" encoding="UTF-8"?><Configuration><Appender

关于文章“python+百度语音识别+星火大模型+讯飞语音合成的语音助手”报错的修改

前言 关于我的文章:python+百度语音识别+星火大模型+讯飞语音合成的语音助手,运行不起来的问题 文章地址: https://blog.csdn.net/Phillip_xian/article/details/138195725?spm=1001.2014.3001.5501 1.报错问题 如果运行中报错,且报错位置在Xufi_Voice.py文件中的pcm_2_wav,如下图所示

【鸿蒙】ERROR_GET_BUNDLE_INSTALLER_FAILED

错误信息 [ERROR_GET_BUNDLE_INSTALLER_FAILED] Troubleshooting guide $ hdc file send D:\Huawei\devEcoProjects\entry\build\default\outputs\default\entry-default-unsigned.hap /sdcard/e8a215ea7be1444197e6a58e