博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JSON文件编辑
阅读量:5907 次
发布时间:2019-06-19

本文共 6488 字,大约阅读时间需要 21 分钟。

  hot3.png

 

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),"utf-8");

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))

{

System.out.println("修改前\t"+jo.toJSONString());

for(String key:editData.keySet())

{

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

}

ja.set(i, jo);

System.out.println("修改后\t"+editData);

System.out.println("修改后\t"+jo.toJSONString());

System.out.println("修改后\t"+ja.getJSONObject(i).toJSONString());

}

}

data.put("rows", ja);

FileUtils.writeStringToFile(new File(f_json), jsonFormatter(data.toJSONString()),"utf-8");

} catch (IOException e) {

System.out.println(jsonFormatter(jsonList));

e.printStackTrace();

}

}

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

{

String jsonList = "";

try {

jsonList = org.apache.commons.io.FileUtils.readFileToString(new File(f_json),"utf-8");

JSONObject data = JSON.parseObject(jsonList);

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

ja.add(0,addData);

data.put("rows", ja);

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

FileUtils.writeStringToFile(new File(f_json), jsonFormatter(data.toJSONString()),"utf-8");

} catch (IOException e) {

System.out.println(jsonFormatter(jsonList));

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),"utf-8");

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);

len -=1;

}

}

//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()),"utf-8");

} catch (IOException e) {

System.out.println(jsonFormatter(jsonList));

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),"utf-8");

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()),"utf-8");

} catch (IOException e) {

System.out.println(jsonFormatter(jsonList));

e.printStackTrace();

}

}

@SuppressWarnings({ "unchecked", "static-access" })

public static Map<String,String> find(String f_json,String field,String fvalue)

{

String jsonList = "";

try {

jsonList = org.apache.commons.io.FileUtils.readFileToString(new File(f_json),"utf-8");

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))

{

return jo.parseObject(jo.toJSONString(), HashMap.class);

}

}

} catch (IOException e) {

System.out.println(jsonFormatter(jsonList));

e.printStackTrace();

}

return new HashMap<String, String>();

}

public static Integer findInteger(String f_json,String field,String fvalue,String ffield)

{

String jsonList = "";

try {

jsonList = org.apache.commons.io.FileUtils.readFileToString(new File(f_json),"utf-8");

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))

{

return jo.getInteger(ffield);

}

}

} catch (IOException e) {

System.out.println(jsonFormatter(jsonList));

e.printStackTrace();

}

return 0;

}

public static String findStr(String f_json,String field,String fvalue,String ffield)

{

String jsonList = "";

try {

jsonList = org.apache.commons.io.FileUtils.readFileToString(new File(f_json),"utf-8");

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))

{

return jo.getString(ffield);

}

}

} catch (IOException e) {

System.out.println(jsonFormatter(jsonList));

e.printStackTrace();

}

return "";

}

/**

* @author 王乾

* @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");

System.out.println(JSONDataUtils.find(f_json, "id", "txl-00006"));

}

 

}

转载于:https://my.oschina.net/body/blog/525703

你可能感兴趣的文章
单点登录实现思路
查看>>
POJ p1979 递归
查看>>
opencv计算时间
查看>>
性能瓶颈的分类
查看>>
maven scope system
查看>>
#综合实践#通过puppet管理远程docker容器——配置puppet和实现变更
查看>>
PLSQL连Oracle数据库Could not load "……\bin\oci.dll"
查看>>
centos6.4安装GitLab
查看>>
Spring(Test)
查看>>
Ruby on Rails vs. PHP vs. Python
查看>>
Android图片剪切
查看>>
如何将 rhevm 加入 AD 域
查看>>
使用putty远程连接linux防止关闭putty程序就停止
查看>>
GCC基本概念及实践(2)
查看>>
Hacker技术是怎么样学习的
查看>>
Linux Vim编辑器的使用技巧
查看>>
oracle 两表关联时,年月条件的写法引起的巨大性能的差异
查看>>
google map初次使用总结
查看>>
OSPF协议介绍及配置 (上)
查看>>
sudo
查看>>