如何根据同一行的ID利用R语言对值进行求和

需求:将属于同一分组的对应的值进行求和或者求平均值

#设置工作目录
> getwd()
[1] "C:/Users/86150/Documents"
> setwd("C:/Users/86150/Desktop/AA2024/RUF")
> list.files()
#读取文件
>install.packages("readxl")
>library("readxl")
> df <- read_excel("202002_RUF_Seed.xlsx")
> head(df)
# A tibble: 6 × 2
  group seed 
  <chr> <chr>
1 R1    5.33 
2 R10   1.8  
3 R10   0.45 
4 R10   5.68 
5 R10   1.48 
6 R105  0,.06

##利用函数aggregate进行分组求和
> merge_data <- aggregate(.~group,data=df,sum())

出现报错:

Error in FUN(X[[i]], ...) : invalid 'type' (character) of argument

You need to remove the color column from the x argument, since it is not being used in aggregation, but is actually the by argument.

aggregate(csv[-1], csv["color"], sum)
#   color val2 val3
# 1  blue    6   13
# 2 green    7    3
# 3   red   11    9

换一种方法还是不行: 

library(dplyr)
df %>% group_by(group) %>% summarise_each(funs(sum))

使用命令 class(df$seed) :检测发现SUM求和的那一列为字符串类型

[1] "character"

 解决方法:

发现是因为seed列为字符型,而sum函数要求数值型,因此只需要将seed转为数值型即可:

figa1 <- df %>% mutate(seed = as.numeric(as.character(seed))) %>% group_by(group) %>% summarize(total = sum(seed))

mutate(seed = as.numeric(as.character(seed)))指的是把count转为数值型

将结果输出:保存为excel的可读形式

#加载“xlsx”
library(xlsx)
library(writexl)
install.packages("openxlsx")  #如果没有这个包就安装
library(openxlsx)

write.xlsx(figa1, "C:/Users/86150/Desktop/AA2024/RUF", append = TRUE)
write_xlsx(figa1, "C:/Users/86150/Desktop/AA2024/RUF")

##这个测试成功了
install.packages("openxlsx")  #如果没有这个包就安装
library(openxlsx)
write.xlsx(figa1, file = file.path("C:/Users/86150/Desktop/AA2024/RUF", "202002ruf_seed.xlsx"))

结果如图:total列显示为每个编号的总的种子总量(备注:因为一个材料编号一般种了三个重复) 

注意事项:在将数据(a.xlsx)导入r语言之前需对数据进行检测,包括sum列的数字格式类型是否为字符串,以及sum值输入时是否存在错误(例如将“.”写成“,”;是否存在中文即非纯数字)

参考文献来源:

R语言中怎么将数据框导出成xlsx文件并规定存放目录_r语言数据导出成xlsx-CSDN博客

R 报错: x invalid 'type' (character) of argument - 橙子牛奶糖 - 博客园 (cnblogs.com)

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-23 10:28:04       52 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-23 10:28:04       54 阅读
  3. 在Django里面运行非项目文件

    2024-07-23 10:28:04       45 阅读
  4. Python语言-面向对象

    2024-07-23 10:28:04       55 阅读

热门阅读

  1. 医学深度学习与机器学习融合的随想

    2024-07-23 10:28:04       24 阅读
  2. 19、基于共享内存的内存池

    2024-07-23 10:28:04       19 阅读
  3. Hisilicon适配按键

    2024-07-23 10:28:04       20 阅读
  4. qml实现双指左右滑动,上下滑动

    2024-07-23 10:28:04       24 阅读
  5. LeetCode 算法:分割回文串 c++

    2024-07-23 10:28:04       26 阅读
  6. 【力扣每日一题】

    2024-07-23 10:28:04       22 阅读
  7. JVM类加载机制详解

    2024-07-23 10:28:04       21 阅读
  8. Python:字典(Dictionary)基础应用

    2024-07-23 10:28:04       19 阅读
  9. 数据结构C++——矩阵【详】

    2024-07-23 10:28:04       15 阅读
  10. 问百度文心一言 下三角矩阵

    2024-07-23 10:28:04       16 阅读