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)就可以顺利转换了
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 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 加持,客户体验更智能