我正在尝试将RDF / XML格式的文档解析为JSON-LD,以便对其进行构架。全部使用Node.js而不使用任何Web服务API(一种不太常见的解决方案)。
我觉得自己快到了,但是至少可以说,我目前的做法显得笨拙。将图放入rdflib存储,然后再次查询它,这给了我一个奇怪的响应,其中包含一些标头,并且图中没有真实的上下文。因此,doc[5]['@graph']
东西在中间。
var fs = require('fs')
var $rdf = require('rdflib')
var jsonld = require('jsonld')
var path = 'path_to_rdf_file'
const frame = {}
fs.readFile(path, 'utf8', function (err, data) {
var uri = 'https://some.other.uri'
var store = $rdf.graph()
$rdf.parse(data, store, uri, 'application/rdf+xml')
var a = $rdf.serialize(null, store, uri, 'application/n-quads')
jsonld.fromRDF(a, { format: 'application/n-quads' }, (err, doc) => {
jsonld.flatten(doc[5]['@graph'], (err, flattened) => {
console.log(flattened)
jsonld.frame(flattened, frame, (err, framed) => {
resolve(framed)
})
})
})
})
由于所有RDF和链接数据包都在npm左右浮动,我认为必须有一个更简单的解决方案可以使我从A转到B。
在不使用rdflib的情况下,如何将RDF / XML文档解析为JSON-LD文档?
最佳答案
您可以使用rdflib
直接序列化为application/ld+json
(rdflib在内部使用jsonld模块)。
var fs = require('fs')
var $rdf = require('rdflib')
var jsonld = require('jsonld')
var path = 'path_to_rdf_file'
const frame = {}
const toJSONLD = (data, uri, mimeType) => {
return new Promise((resolve, reject) => {
var store = $rdf.graph()
$rdf.parse(data, store, uri, mimeType)
$rdf.serialize(null, store, uri, 'application/ld+json', (err, jsonldData) => {
if (err) return reject(err);
resolve(JSON.parse(jsonldData))
})
})
}
fs.readFile(path, 'utf8', function (err, data) {
var uri = 'https://some.other.uri'
toJSONLD(data, uri, 'application/rdf+xml')
.then((doc) => {
jsonld.flatten(doc[5]['@graph'], (err, flattened) => {
console.log(flattened)
jsonld.frame(flattened, frame, (err, framed) => {
resolve(framed)
})
})
})
})
另一种方法是使用
jsonld
(https://www.npmjs.com/package/jsonld#custom-rdf-parser)为jsonld.regiserRDFParser
配备用于您的数据类型的自定义解析器。尽管您可能也将rdflib
用于此任务。