如何在Android中将光标对象转换为XML或JSON

4

是否有可用于将游标对象转换为直接XML或JSON的库。

例如,我们有一个具有两个列id和name的表。当我从数据库获取游标对象时,我想将其转换为XML或JSON格式,而不需要循环遍历游标对象。

<XML>
<id>1<id>
<name>xyz</name>
</XML>

Thanks in advance.


你想要 XML 还是 JSON? - Kishan Dhamat
请查看我提供的链接。 - Kishan Dhamat
2个回答

3

假设我有一个名为“persons”的表格,其中包含一些数据

id | 名字 | 姓氏

1 | 约翰 | 多伊

2 | 简 | 史密斯

这是我的简单代码:

public String getRecords(String selectQuery){
    String recordSet = null;
    Cursor mCursor = database.rawQuery(selectQuery, null); 
    String[] colName = mCursor.getColumnNames();
   if (mCursor != null) {  

      recordSet = "{";
      mCursor.moveToFirst();

      do{
          StringBuilder sb = new StringBuilder();
          int columnsQty = mCursor.getColumnCount();
          for(int idx=0; idx<columnsQty; ++idx){
              sb.append(mCursor.getString(idx));
              if(idx<columnsQty-1){
                  sb.append(";");
              }
          }
          if(mCursor.getPosition()>0){
              recordSet +=",";
          }

          String row = formatRecords(colName, sb.toString());
          recordSet+= "\""+mCursor.getPosition()+"\":["+row+"]";

      }while(mCursor.moveToNext());

      recordSet += "}";

      return recordSet;


   }    
}
public String formatRecords(String[] colname, String rowData){
    String formatedData = null;
    String[] data = rowData.split(";");
    int colCount = colname.length;
    if(rowData !=null){
        formatedData = "{";
        for(int col=0; col<colCount; col++){
            if(col>0){
                formatedData += ", ";
            }
            formatedData += "\""+colname[col]+"\":\""+data[col]+"\"";
        }
        formatedData += "}";
    }
    Log.i(tag, formatedData);
    return formatedData

那么我将用它作为:
String data = getRecords("SELECT * FROM persons");

返回结果将如下所示:

{"0":[{"id":"1","name":"john","lastname":"Doe"}],"1":[{"id":"2","name":"jane","lastname":"Smith"}]}

无论如何,我将返回类型设置为字符串以供通用目的。 :) 谢谢。

这是一个返回JSON格式的字符串。但如果你想打印XML,你可以使用同样的方法应用XML格式。有关制作XML的详细信息,请参阅此链接:https://dev59.com/qnVC5IYBdhLWcg3w9F89 - wehpogi

3
使用以下内容:
JSONArray array = new JSONArray();
    if (cursor != null && cursor.getCount() > 0) {
        while (cursor.moveToNext()) {
            JSONObject object = new JSONObject();
            try {
                object.put("id", cursor.getString(0));
                object.put("name", cursor.getString(1));
                array.put(object);
            } catch (JSONException e) {
                e.printStackTrace();
            }

        }

如果您想创建XML数据,请使用此链接:链接。希望这能帮助到您。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接