r - 仅重命名数据框列表中每个数据框的最后一列
问题描述
我想重命名数据框列表中的每个数据框的最后一列。新名称对所有人都是一样的。
我制作了提取最后一列(如下)的代码,但没有重命名最后一列标题。
List <- lapply(List, function(x) x[,ncol(x)])
解决方案
你可以做
lapply(lst, function(x) {names(x) <- c(names(x[-length(x)]), "new_name");x})
#[[1]]
# mpg cyl disp hp drat wt qsec vs am gear new_name
#Mazda RX4 21.0 6 160 110 3.90 2.620 16.46 0 1 4 4
#Mazda RX4 Wag 21.0 6 160 110 3.90 2.875 17.02 0 1 4 4
#Datsun 710 22.8 4 108 93 3.85 2.320 18.61 1 1 4 1
#Hornet 4 Drive 21.4 6 258 110 3.08 3.215 19.44 1 0 3 1
#Hornet Sportabout 18.7 8 360 175 3.15 3.440 17.02 0 0 3 2
#Valiant 18.1 6 225 105 2.76 3.460 20.22 1 0 3 1
#[[2]]
# mpg cyl disp hp drat wt qsec vs am gear new_name
#Mazda RX4 21.0 6 160 110 3.90 2.620 16.46 0 1 4 4
#Mazda RX4 Wag 21.0 6 160 110 3.90 2.875 17.02 0 1 4 4
#Datsun 710 22.8 4 108 93 3.85 2.320 18.61 1 1 4 1
#Hornet 4 Drive 21.4 6 258 110 3.08 3.215 19.44 1 0 3 1
#Hornet Sportabout 18.7 8 360 175 3.15 3.440 17.02 0 0 3 2
#Valiant 18.1 6 225 105 2.76 3.460 20.22 1 0 3 1
或者@Shree 提到的更简单的版本
lapply(lst, function(x) {names(x)[ncol(x)] <- "new_name";x})
我们也可以使用rename_at
library(dplyr)
library(purrr)
map(lst,. %>% rename_at(ncol(.), ~"new_name"))
数据
lst <- list(head(mtcars), head(mtcars))
推荐阅读
- python - 在 python 代码中使用 http.server 命令行
- javascript - this.prop.state.location.url 未定义?React Js 链接道具
- onclick - 避免在 React Hooks 中重新渲染列表
- r - 有谁知道如何在 R 中使用 ggplot2 制作这样的图表?
- python - 改变的skip-gram模型的keras实现的意外行为
- node.js - NodeJS Soap 服务 - 返回同步响应客户端
- css - 范围样式总是被覆盖
- pine-script - 为什么 PineScript 告诉我我的 TEMA 不是函数?
- javascript - 如何使用angular 9服务和电子主进程设置ipc
- html - 使用 flexbox 和控件对齐方式在一行中显示两个按钮