码迷,mamicode.com
首页 > Web开发 > 详细

JSON文件编辑

时间:2015-11-04 11:35:38      阅读:267      评论:0      收藏:0      [点我收藏+]

标签:

 

import java.io.File;

import java.io.IOException;

import java.util.HashMap;

import java.util.Map;


import org.apache.commons.io.FileUtils;

import org.apache.commons.lang.StringUtils;


import com.alibaba.fastjson.JSON;

import com.alibaba.fastjson.JSONArray;

import com.alibaba.fastjson.JSONObject;

import com.google.gson.Gson;

import com.google.gson.GsonBuilder;

import com.google.gson.JsonElement;

import com.google.gson.JsonParser;



 

public class JSONDataUtils {

public static void edit(String f_json,String field,String fvalue,Map<String,Object> editData)

{

String jsonList = "";

try {

jsonList = org.apache.commons.io.FileUtils.readFileToString(new File(f_json));

JSONObject data = JSON.parseObject(jsonList);

JSONArray ja = data.getJSONArray("rows");

int len = ja.size();

for(int i = 0;i<len;i++)

{

JSONObject jo = ja.getJSONObject(i);

if(jo.getString(field).equals(fvalue))

{

for(String key:editData.keySet())

{

jo.put(key, editData.get(key));

}

ja.set(i, jo);

}

}

data.put("rows", ja);

FileUtils.writeStringToFile(new File(f_json), jsonFormatter(data.toJSONString()));

} catch (IOException e) {

e.printStackTrace();

}

}

public static void add(String f_json,Map<String,Object> addData)

{

String jsonList = "";

try {

jsonList = org.apache.commons.io.FileUtils.readFileToString(new File(f_json));

JSONObject data = JSON.parseObject(jsonList);

JSONArray ja = data.getJSONArray("rows");

ja.add(addData);

data.put("rows", ja);

data.put("total", data.getInteger("total")+1);

FileUtils.writeStringToFile(new File(f_json), jsonFormatter(data.toJSONString()));

} catch (IOException e) {

e.printStackTrace();

}

}


public static void del(String f_json,String field,String fvalue)

{

String jsonList = "";

try {

jsonList = org.apache.commons.io.FileUtils.readFileToString(new File(f_json));

JSONObject data = JSON.parseObject(jsonList);

JSONArray ja = data.getJSONArray("rows");

int len = ja.size();

for(int i = 0;i<len;i++)

{

JSONObject jo = ja.getJSONObject(i);

if(jo.getString(field).equals(fvalue))

{

ja.remove(jo);

}

}

//System.out.println(ja.toJSONString());

data.put("rows", ja);

data.put("total", data.getInteger("total")-1);

//System.out.println(data.toJSONString());

FileUtils.writeStringToFile(new File(f_json), jsonFormatter(data.toJSONString()));

} catch (IOException e) {

e.printStackTrace();

}

}

public static void batDel(String f_json,String field,String fvalues)

{

String jsonList = "";

try {

jsonList = org.apache.commons.io.FileUtils.readFileToString(new File(f_json));

JSONObject data = JSON.parseObject(jsonList);

JSONArray ja = data.getJSONArray("rows");

int len = ja.size();

String[] fv = fvalues.split(",");

System.out.println(fvalues);

for(int i = 0;i<len;i++)

{

JSONObject jo = ja.getJSONObject(i);

for(String fvalue:fv)

{

if(StringUtils.isBlank(fvalue)

||StringUtils.isEmpty(fvalue))

{

continue;

}

if(jo.getString(field).equals(fvalue))

{

ja.remove(jo);

len -= 1;

System.out.println("删除一条");

}

}

}

//System.out.println(ja.toJSONString());

data.put("rows", ja);

data.put("total", data.getInteger("total")-fv.length);

//System.out.println(data.toJSONString());

FileUtils.writeStringToFile(new File(f_json), jsonFormatter(data.toJSONString()));

} catch (IOException e) {

e.printStackTrace();

}

}

/**

*  

* @comments 格式化至可视模式

* @time  2015-11-4上午11:25:19

* @param  uglyJSONString

* @return 

* @returnType String

* @modification

*/

public static String jsonFormatter(String uglyJSONString){

        Gson gson = new GsonBuilder().setPrettyPrinting().create();

        JsonParser jp = new JsonParser();

        JsonElement je = jp.parse(uglyJSONString);

        String prettyJsonString = gson.toJson(je);

        return prettyJsonString;

    }

 

public static void main(String[] args) {

String f_json = "D:\\workspaces\\demo\\WebRoot\\data\\bgs\\txl.json";

Map<String,Object> editData = new HashMap<String, Object>();

editData.put("txlstatu", "同意修改");

JSONDataUtils.edit(f_json, "id", "txl-00001",editData);

editData.put("id", "txl-00011");

JSONDataUtils.add(f_json, editData);

editData.put("id", "txl-00012");

JSONDataUtils.add(f_json, editData);

JSONDataUtils.del(f_json, "id", "txl-00012");

JSONDataUtils.batDel(f_json, "id", "txl-00011,txl-00012");

}


}


JSON文件编辑

标签:

原文地址:http://my.oschina.net/body/blog/525703

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!