提问人:Dhiraj 提问时间:3/8/2017 最后编辑:CommunityDhiraj 更新时间:3/9/2017 访问量:35
在 RNeo4j 中使用“appendCypher()”时出错
Errors while using `appendCypher()` in RNeo4j
问:
我正在尝试使用该包在 R 中创建一个图形数据库。基本上,@Nicloe White 在这里展示的是我试图完全通过 RStudio IDE 实现的目标。我已将数据读入 R 中,并使用该包对日期字段进行了一些基本的内务处理。此后,我将遵循 Nicole 在此处为数据集显示的内容。这是相关代码:RNeo4j
lubridate
hflights
query="
CREATE (complaint:Complaint {id: TOINT({ComplaintID})})
SET complaint.day = ({ComplaintDay}),
complaint.month = ({ComplaintMonth}),
complaint.year = ({ComplaintYear})
MERGE (company:Company {name:{CompanyName}})
MERGE (response:Response {name:{Companyresponsetoconsumer}})
CREATE (complaint) -[:AGAINST]-> (company)
CREATE (response) -[r:TO]-> (complaint)
SET r.timely = CASE {Timelyresponse} WHEN 'Yes' THEN true ELSE false END,
r.disputed = CASE {Consumerdisputed} WHEN 'Yes' THEN true ELSE false END
"
tx = newTransaction(graph)
for(i in 1:nrow(complaint)) {
row = complaint[i, ]
appendCypher(tx, query,
ComplaintID=complaint$Complaint.ID,
ComplaintDay=complaint$Complaint.Day,
ComplaintMonth=complaint$Complaint.Month,
ComplaintYear=complaint$Complaint.Year,
CompanyName=complaint$Company,
Companyresponsetoconsumer=complaint$Company.response.to.consumer,
Timelyresponse=complaint$Timely.response.,
Consumerdisputed=complaint$Consumer.disputed.)
}
commit(tx)
summary(graph)
但是,当我运行循环时,出现以下错误:for
Error in appendCypher.transaction(tx, query, ComplaintID =
complaint$Complaint.ID, :
Neo.ClientError.Statement.TypeError
Expected a String or Number, got: List(1913026, 99413, 1420666, 1139505, 850511, 211452, 299293, 967118, 1342525, 218870, 936088, 1577433, 396460, 976892, 1713179, 985796, 1274906, 1524883, 549683, 375379, 2083877, 1804301, 568928, 643695, 2013448, 1822596, 1054868, 1058533, 1972148, 1053127, 1546919, 1974786, 1386150, 558306, 2029982, 1812827, 2112000, 1279031, 1729024, 811685, 423229, 211371, 550247, 1837165, 589977, 363963, 773706, 1422738, 362615, 1918434, 31932, 101419, 109634, 799711, 568707, 425802, 1354727, 905367, 433560, 950090, 1615178, 1085081, 1842311, 55218, 82206, 8990, 1716274, 1199075, 315208, 976080, 1747751, 1424814, 757803, 61250, 592018, 974917, 2046258, 1901776, 123518, 1362552, 257123, 1212622, 1663172, 1200587, 84365, 358901, 1920239, 691273, 226122, 36142, 1615314, 809300, 1987176, 596079, 1619346, 1261257, 984128, 793228, 173250, 249440, 192131, 1759419, 1394747, 1316550, 1890080, 862502, 1192961, 506058, 2000389,
状态代码指示可能不支持该类型。但是难道不照顾这个吗?complaint$Complaint.ID
TOINT
请在这里提供一些帮助。
答:
0赞
Dhiraj
3/9/2017
#1
这是一个非常愚蠢的错误。这是有效的:for
for(i in 1:nrow(complaint)) {
row = complaint[i, ]
appendCypher(tx, query,
ComplaintID=row$Complaint.ID,
ComplaintDay=row$Complaint.Day,
ComplaintMonth=row$Complaint.Month,
ComplaintYear=row$Complaint.Year,
CompanyName=row$Company,
Companyresponsetoconsumer=row$Company.response.to.consumer,
Timelyresponse=row$Timely.response.,
Consumerdisputed=row$Consumer.disputed.)
}
上一个:从 R 多次提交到 neo4j
评论
str(complaint$Complaint.ID)
显示它是一个整数。