如何通过 SPARQL 精确匹配单词

发布于 2024-10-24 20:47:04 字数 842 浏览 9 评论 0原文

我的应用程序需要将正确的单词(即 C 或 C++)与 SPARQL 相匹配。我有以下 SPARQL 查询

String prolog = "PREFIX kb: <" + VBOOK.getURI() + ">";

String queryString = prolog

+ "\n"

+ "SELECT * "

+ "WHERE {?x kb:Price ?price. ?x kb:Currency ?currency. ?x kb:Title ?title. ?x kb:Count ?count. "

+ "OPTIONAL {?x kb:Description ?description}."

+ "FILTER regex(?title, \"" +title + "\")}";

这与我所有的书籍相匹配,甚至包括 C++、C# 和诸如 -Real Concepts in Embedded Systems 之类的书籍(因为“Concepts”一词有“C”)。

如果我将最后一行更改为

+ "FILTER regex(?title, \"" +"^"+title + "\")}";

并且标题例如为“C”,那么我的查询仅匹配那些标题以字母“C”开头的书籍。因此不会选择“Programming in ANSI C”之类的书籍。

我还尝试在最后一行进行以下更改

+ "FILTER regex(str(?title), \"" +title + "\")}";

即使这对我没有多大帮助。

即使书名不是以 C 开头,如何修改才能获取与“C”相关的书籍?

问候, 阿卡纳。

My application needs to match the correct word i.e. say C or C++ with SPARQL. I have the following SPARQL query

String prolog = "PREFIX kb: <" + VBOOK.getURI() + ">";

String queryString = prolog

+ "\n"

+ "SELECT * "

+ "WHERE {?x kb:Price ?price. ?x kb:Currency ?currency. ?x kb:Title ?title. ?x kb:Count ?count. "

+ "OPTIONAL {?x kb:Description ?description}."

+ "FILTER regex(?title, \"" +title + "\")}";

This matches me all books even C++,C# and books like -Real Concepts in Embedded Systems (because of the word 'Concepts' having 'C').

if I change the last line to

+ "FILTER regex(?title, \"" +"^"+title + "\")}";

and if title is for example 'C' then my query matches only those books whose titles start with letter 'C'.So books like 'Programming in ANSI C' are not selected.

I have also tried with the following change in the last line

+ "FILTER regex(str(?title), \"" +title + "\")}";

Even this has not helped me much.

How do I modify to get the books pertaining to 'C' even if the books title do not start with C?

Regards,
Archana.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

非要怀念 2024-10-31 20:47:04

这个问题归结为您的查询引擎支持哪些正则表达式功能。如果它支持 \b 字边界匹配,您可以通过将最后一行更改为来解决您的问题

 + "FILTER regex(?title, \"\\b" + title + "\\b\")}";

This question boils down to what regular expression features your query engine supports. If it supports \b word boundary matching, you can solve your problem by changing the last line to

 + "FILTER regex(?title, \"\\b" + title + "\\b\")}";
り繁华旳梦境 2024-10-31 20:47:04

你需要正则表达式吗?

不要将 title 设置为变量,只需将其修复为 -

?x kb:Title "title" 。

即在您的代码中

String title = "C++";

"WHERE {?x kb:价格 ?价格。?x kb:货币 ?货币。?x kb:标题 \""+标题+"\" 。?x kb:计数 ?计数。"

Do you need regex at all?

Instead of making title a variable, simply fix it so -

?x kb:Title "title" .

i.e. in your code

String title = "C++";

"WHERE {?x kb:Price ?price. ?x kb:Currency ?currency. ?x kb:Title \""+title+"\" . ?x kb:Count ?count. "

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文