1

ここではLucentライブラリを使用してプロジェクトを行っています。Jsonオブジェクトを使用して動的にクエリを作成する必要があります。ここでは、jettisonライブラリを使用します。例として、このような私のjson

{"OR":{"OR": {"fildKey1": "value1","fildKey2": "value2","fildKeyabc": "valueabc"},"AND": {"AND": {"fildKey3": "value3","OR": {"fildKey4": "value4","fildKey5": "value5"}},"fildKeyw": "valuew"}}}

上記のjsonを使用して、次のクエリを作成する必要があります

(( fildKey1 : value1 OR fildKey2 : value2 OR fildKeyabc : valueabc )OR(( fildKey3 : value3 AND( fildKey4 : value4 OR fildKey5 : value5 ))AND fildKeyw : valuew ))

しかし、上記のクエリを取得できません。私の結果は次のようになります

(( fildKey1 : value1 OR fildKey2 : value2 OR fildKeyabc : valueabc )OR(( fildKey3 : value3 AND( fildKey4 : value4 OR fildKey5 : value5 )AND)AND fildKeyw : valuew )OR)

上記の余分な2つの演算子を削除する必要がありますこれは私のコードです

public class JettisionCls {
   static Stack s = new Stack();
   String operater = null;
   static String res = "";
   int bracket_counter = 0;   


public void getKeyAndValue(JSONObject json_obj) throws JSONException{
    Iterator<String> iter = json_obj.keys();

    while (iter.hasNext()) {
        String obj = iter.next();
        if(obj.toLowerCase().equals("and") || obj.toLowerCase().equals("or")){
            //System.out.print(obj);
            operater = obj;              
        }

        JSONObject temp = null;
        try {
            temp = new JSONObject(json_obj.get(obj).toString());
        } catch (JSONException e) {
            e.getStackTrace();
        }

        if (temp != null) {
            //System.out.print("(");
            res = res +"(";
            bracket_counter=bracket_counter+1;
            s.push(operater);

            getKeyAndValue(temp);

            //System.out.print(")");
            res = res +")";
            bracket_counter=bracket_counter-1;                          
            if((s.size()) != 0 && bracket_counter != 0){
                //System.out.print(s.peek());
                s.pop();
                res = res +s.peek(); 
            }
            else{
                s.pop();
            }
        }            
        else{
            if(iter.hasNext()){
                res = res+" "+obj + " : " + json_obj.get(obj) + " " + operater;                                    }
            else{
                res = res+" "+obj + " : " + json_obj.get(obj)+" ";
            }
        }
    }
}

私の主な方法は次のようになります

String multiLevelQuery = "{\"OR\":{\"OR\": {\"fildKey1\": \"value1\",\"fildKey2\": \"value2\",\"fildKeyabc\": \"valueabc\"},\"AND\": {\"AND\": {\"fildKey3\": \"value3\",\"OR\": {\"fildKey4\": \"value4\",\"fildKey5\": \"value5\"}},\"fildKeyw\": \"valuew\"}}}";

JSONObject jobj = new JSONObject(multiLevelQuery);
JettisionCls obj = new JettisionCls();
obj.getKeyAndValue(jobj);
System.out.println(JettisionCls.res);

誰かが私を助けてくれるなら。

4

2 に答える 2

2

文字列置換を使用してこれを行うことができると思います。

public void createQry(String s){
    String temp = s;

    if(temp.contains(")OR)")){
        temp = temp.replace(")OR)", "))");
    }
    if(s.contains(")AND)")){
        temp = temp.replace(")AND)", "))");
    }
    System.out.println(temp);        
}
于 2012-08-22T05:23:45.080 に答える
0

うーん、これは興味深い問題です。しかし、ブルートフォースの代わりに、私はのようなもっとエレガントなものを使っていただろうrecursion。プッシュ、ポップ、および連結は、再帰によって実行されます。あなたのコードでは、それが壊れる可能性のある多くの場所を見ることができます。この問題を修正しても、別の条件で失敗する可能性があります。

再帰を使用したサンプルアルゴリズムは次のようになります。

public String generateQuery(JSONObject json_obj) {

if(single_json_obj)
   return generated_query_for_single_condition;

//else complex json with inner children
else
   return generateQuery(innerJSONObject)
}

}

于 2012-07-29T11:40:31.417 に答える