正则表达式 – SPARQL正则表达式不匹配
发布时间:2020-12-14 06:00:19 所属栏目:百科 来源:网络整理
导读:我希望在标题中没有“The Lord of the rings”字符串的情况下获得所有电影.我在 Linked Movie Database SPARQL endpoint尝试了这个,但它不起作用.怎么了? PREFIX m: http://data.linkedmdb.org/resource/movie/SELECT DISTINCT * WHERE { ?film dc:title ?t
我希望在标题中没有“The Lord of the rings”字符串的情况下获得所有电影.我在
Linked Movie Database SPARQL endpoint尝试了这个,但它不起作用.怎么了?
PREFIX m: <http://data.linkedmdb.org/resource/movie/> SELECT DISTINCT * WHERE { ?film dc:title ?titulo_pelicula. FILTER NOT EXISTS { FILTER (regex(?titulo_pelicula,"The Lord of the Rings","i")) . } } 解决方法
首先,你应该澄清你的意思“不起作用.”首先,我认为你的意思是它没有返回任何结果,但当我在
the endpoint运行时,我意识到你实际上得到一个关于错误的相当清晰的错误消息:
Parse error: PREFIX owl: <http://www.w3.org/2002/07/owl#> PREFIX xsd: <http://www.w3.org/2001/XMLSchema#> PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#> PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> PREFIX foaf: <http://xmlns.com/foaf/0.1/> PREFIX oddlinker: <http://data.linkedmdb.org/resource/oddlinker/> PREFIX map: <file:/C:/d2r-server-0.4/mapping.n3#> PREFIX db: <http://data.linkedmdb.org/resource/> PREFIX dbpedia: <http://dbpedia.org/property/> PREFIX skos: <http://www.w3.org/2004/02/skos/core#> PREFIX dc: <http://purl.org/dc/terms/> PREFIX movie: <http://data.linkedmdb.org/resource/movie/> PREFIX m: <http://data.linkedmdb.org/resource/movie/> SELECT DISTINCT * WHERE { ?film dc:title ?titulo_pelicula. FILTER NOT EXISTS { FILTER (regex(?titulo_pelicula,"i")) . } } Lexical error at line 16,column 14. Encountered: " " (32),after : "NOT" 当你到达NOT时,你有一个解析错误.端点基于原始SPARQL Query Language for RDF而不是SPARQL 1.1 Query Language.原始SPARQL没有NOT EXISTS. 这很容易解决.首先,要认识到过滤器采用表达式并仅保留表达式计算结果为true的结果.当正则表达式与标题匹配时,过滤器表达式正则表达式(?titulo_pelicula,“指环王”,“我”)返回true,并且您正在查找返回false的情况,因此您只需要取消它用! (!运算符与XPath函数不同.映射在SPARQL建议的第11.3 Operator Mapping节中定义.)您需要这样的查询: PREFIX m: <http://data.linkedmdb.org/resource/movie/> SELECT DISTINCT * WHERE { ?film dc:title ?titulo_pelicula. FILTER (!regex(?titulo_pelicula,"i")) . } SPARQL results (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |