weixin_51474861 2023-02-06 15:47 采纳率: 33.3%
浏览 62
已结题

R语言,函数报错解决

#APdobs_NTPD.fn函数:计算NTPD观察值,长度为focalsp的长度

focalsp<-read.csv("1.csv",header=T,fileEncoding="GBK")  ##目标个体的种名
pdmatrix<-read.csv("2.csv",header=T,fileEncoding="GBK")#系统发育距离矩阵
sample<-read.csv("1.csv",header=T,fileEncoding="GBK")#周围邻体的其他种类
as.matrix(focalsp)
as.matrix(pdmatrix)
as.matrix(sample)
APdobs_NTPD.fn =function(focalsp,pdmatrix,sample)
  #focalsp为目标个体的种名,pdmatrix为系统发育距离矩阵(标准化成0-1,参考Liza的课件),spinsample为周围邻体的其他种类
{
  pdtofocal.min =numeric()
  for(i in 1:length(focalsp))
  {
    spinsample=rownames(sample)[sample[,i]!=0]
    spinsample.abund=sample[,i][sample[,i]!=0]
    focalsp.pos=which(rownames(pdmatrix)==focalsp[i])
    spinsample.pos=match(spinsample,colnames(pdmatrix))
    pdtofocal=numeric()
    for(j in 1:length(spinsample.pos))
    {
      pdtofocal[j]=pdmatrix[focalsp.pos,spinsample.pos[j]]
    }
    pdtofocal.min[i]=min(pdtofocal)
  }
  return(pdtofocal.min)
}

write.table(APdobs_NTPD.fn,"APdobs_NTPD.fn")

报错:Error in as.data.frame.default(x[[i]], optional = TRUE) :
cannot coerce class ‘"function"’ to a data.frame

  • 写回答

2条回答 默认 最新

  • 社区专家-Monster-XH 2023-02-06 16:09
    关注
    results <- APdobs_NTPD.fn(focalsp,pdmatrix,sample)
    write.table(results, "APdobs_NTPD.fn")
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 2月15日
  • 已采纳回答 2月7日
  • 创建了问题 2月6日

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵