我试图弄清楚如何编写 MQL 查询以获取与给定单词关联的所有类型的列表。
例如我试过:
{
"id":null,
"name":null,
"name~=": "SOME_WORD",
"type":"/type/type",
"domain": {
"id": null,
"/freebase/domain_profile/category": {
"id": "/category/commons"
}
}
}
我发现这列出了所有 Commons 类型或类别,但还没有想出如何缩小给定输入的范围。
[{
"id": null,
"name": null,
"type": "/freebase/domain_profile",
"category": {
"id": "/category/commons"
}
}]
最佳答案
有几种不同的方法可以做到这一点,每种方法都有不同的权衡。
https://www.googleapis.com/freebase/v1/search?indent=true&filter=%28all%20name {full}:%22uss%20constitution%22%29
您将返回如下所示的 JSON 结果:
{
"status": "200 OK",
"result": [
{
"mid": "/m/07y14",
"name": "USS Constitution",
"notable": {
"name": "Ship",
"id": "/boats/ship"
},
"lang": "en",
"score": 1401.410400
},
...
您可以通过将“{full}”切换为“{phrase}”来使匹配更加自由,这将为您提供子字符串匹配而不是精确匹配。
注意事项:
- 你只会得到一个“显着类型”,它是由 Freebase 的(未知)算法修复的
- 我认为没有办法同时获得 USS 宪法和 USS.宪法结果
- 您可以通过添加 &mql_output={"type":[]} 来获取所有类型的列表,但是您会丢失“显着”类型。我认为没有办法在一次通话中同时获得两者。
此查询返回您想要的基本信息:
[{
"name~=":"uss constitution",
"type":[],
"/common/topic/notable_types" : []
}]
注意事项:
根据您要完成的任务,您可能需要比这更复杂的东西(以及对 Freebase 中的内容有更深入的了解),但这应该可以帮助您掌握基础知识。
关于json - Freebase MQL 列出给定单词的所有公共(public)类型?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/9491528/