加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

正则表达式 – 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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读