RMongodb 在转换数据的一些问题

先上代码


####### Get Datas from MongoDb #######
##Summary:
##Range: Internal
##Args:
#arg_db: Instance of MongoDb
#arg_strNS: Namespace  ("NDAP.BondVariety")
#arg_bRemoveId: Remove the "_id" column from datas
##Return:
#Return: Date Frame
GetDatasMongo_Tool = function(arg_db , arg_strNS , arg_bRemoveId)
{  
  if(!mongo.is.connected(arg_db))
    print("Mongo is not be connected")
  
  lst_frm = list()
  
  it = mongo.find(arg_db,arg_strNS,mongo.bson.empty())  
  i=1
  while(mongo.cursor.next(it))  
  {    
    nTest <<- nTest + 1
    bsonTmp = mongo.cursor.value(it)
    lst = mongo.bson.to.list(bsonTmp)  
    if(arg_bRemoveId)
      lst[["_id"]]<-NULL   
          
    lst[sapply(lst,is.null)]<-NaN
    
        
    lst_frm[[i]] = data.frame(lst)  
    i=i+1
  }
  dfrm = do.call(rbind,lst_frm)
  
  dfrm
}


注意这句话  

    lst[sapply(lst,is.null)]<-NaN

之前没有加这行时 在 data.frame(lst) 报错误,

Error in data.frame(Id = "100002.IB", preClose = 97.2136, open = 97.2136,  : 
  arguments imply differing number of rows: 1, 0

后来发现是lst (这是一个list) 中含有数据为NULL , 这样的数据无法转成dataframe 

后来通过   lst[sapply(lst,is.null)]<-NaN 这句话,把lst中所有的NULL都转成NAN (not a number)就可以顺利转换了



posted on   norsd  阅读(163)  评论(0编辑  收藏  举报

编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· DeepSeek在M芯片Mac上本地化部署
· 葡萄城 AI 搜索升级:DeepSeek 加持,客户体验更智能

导航

< 2013年5月 >
28 29 30 1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31 1
2 3 4 5 6 7 8
点击右上角即可分享
微信分享提示