Issue 541 - add support for constraints on key queries in Freebase
git-svn-id: http://google-refine.googlecode.com/svn/trunk@2449 7d457c2a-affb-35e4-300a-418c747d4874
This commit is contained in:
parent
8ff6c5617f
commit
b784046b18
@ -140,6 +140,20 @@ public class FreebaseDataExtensionJob {
|
|||||||
return new DataExtension(data);
|
return new DataExtension(data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void storeKey(
|
||||||
|
List<Object[]> rows,
|
||||||
|
int row,
|
||||||
|
int col,
|
||||||
|
JSONObject key,
|
||||||
|
Map<String, ReconCandidate> reconCandidateMap
|
||||||
|
) throws JSONException {
|
||||||
|
String keyval = key.getString("value");
|
||||||
|
while (row >= rows.size()) {
|
||||||
|
rows.add(new Object[columnCount]);
|
||||||
|
}
|
||||||
|
rows.get(row)[col] = keyval;
|
||||||
|
}
|
||||||
|
|
||||||
protected void storeCell(
|
protected void storeCell(
|
||||||
List<Object[]> rows,
|
List<Object[]> rows,
|
||||||
int row,
|
int row,
|
||||||
@ -192,7 +206,20 @@ public class FreebaseDataExtensionJob {
|
|||||||
JSONArray a = resultNode != null && resultNode.has(propertyID) && !resultNode.isNull(propertyID) ?
|
JSONArray a = resultNode != null && resultNode.has(propertyID) && !resultNode.isNull(propertyID) ?
|
||||||
resultNode.getJSONArray(propertyID) : null;
|
resultNode.getJSONArray(propertyID) : null;
|
||||||
|
|
||||||
if (expectedTypeID.startsWith("/type/")) {
|
if ("/type/key".equals(expectedTypeID)) {
|
||||||
|
if (a != null) {
|
||||||
|
int l = a.length();
|
||||||
|
for (int r = 0; r < l; r++) {
|
||||||
|
Object o = a.isNull(r) ? null : a.get(r);
|
||||||
|
if (o instanceof JSONObject) {
|
||||||
|
storeKey(rows, startRowIndex++, startColumnIndex, (JSONObject) o, reconCandidateMap);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// note that we still take up a column even if we don't have any data
|
||||||
|
return new int[] { startRowIndex, startColumnIndex + 1 };
|
||||||
|
} else if (expectedTypeID.startsWith("/type/")) {
|
||||||
if (a != null) {
|
if (a != null) {
|
||||||
int l = a.length();
|
int l = a.length();
|
||||||
for (int r = 0; r < l; r++) {
|
for (int r = 0; r < l; r++) {
|
||||||
@ -340,7 +367,8 @@ public class FreebaseDataExtensionJob {
|
|||||||
writer.key(propertyID);
|
writer.key(propertyID);
|
||||||
writer.array();
|
writer.array();
|
||||||
{
|
{
|
||||||
if (!expectedTypeID.startsWith("/type/")) { // not literal
|
if (!expectedTypeID.startsWith("/type/") // not literal
|
||||||
|
|| "/type/key".equals(expectedTypeID)) {
|
||||||
writer.object();
|
writer.object();
|
||||||
writer.key("optional"); writer.value(true);
|
writer.key("optional"); writer.value(true);
|
||||||
|
|
||||||
@ -374,13 +402,10 @@ public class FreebaseDataExtensionJob {
|
|||||||
if (sortKey.startsWith("-")) {
|
if (sortKey.startsWith("-")) {
|
||||||
sortKey = sortKey.substring(1);
|
sortKey = sortKey.substring(1);
|
||||||
}
|
}
|
||||||
writer.key(sortKey);
|
writer.key(sortKey); writer.value(null);
|
||||||
writer.value(null);
|
writer.key(name); writer.value(value);
|
||||||
writer.key(name);
|
|
||||||
writer.value(value);
|
|
||||||
} else {
|
} else {
|
||||||
writer.key(name);
|
writer.key(name); writer.value(value);
|
||||||
writer.value(value);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -392,8 +417,12 @@ public class FreebaseDataExtensionJob {
|
|||||||
boolean hasSubProperties = (node.has("properties") && !node.isNull("properties"));
|
boolean hasSubProperties = (node.has("properties") && !node.isNull("properties"));
|
||||||
|
|
||||||
if (!hasSubProperties || (node.has("included") && node.getBoolean("included"))) {
|
if (!hasSubProperties || (node.has("included") && node.getBoolean("included"))) {
|
||||||
writer.key("name"); writer.value(null);
|
if ("/type/key".equals(expectedTypeID)) {
|
||||||
writer.key("id"); writer.value(null);
|
writer.key("value"); writer.value(null);
|
||||||
|
} else {
|
||||||
|
writer.key("name"); writer.value(null);
|
||||||
|
writer.key("id"); writer.value(null);
|
||||||
|
}
|
||||||
writer.key("type"); writer.array(); writer.endArray();
|
writer.key("type"); writer.array(); writer.endArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user