调用方法:
LocalSetupHelper.SetData(Sss.维护, "密码", "123456");  //保存

var c=LocalSetupHelper.GetData(Sss.前台, "密码"); 获取

LocalSetupHelper.RemovePropertyName(Sss.前台, "密码"); //清除子节点

LocalSetupHelper.RemovePropertyName(Sss.前台); 清除父节点

enum Sss
{
维护,
前台,
}

输出格式:

{
"前台": {
"密码": "123456",
},
"维护": {
"密码": "123456"
}
}

Demo: 拿来直接用

public static class LocalSetupHelper
{
#region 字段
/// <summary>
/// json文本
/// </summary>
private static string json;
/// <summary>
/// 指定保存路径
/// </summary>
public static string path { get; set; }
#endregion #region 构造函数
static LocalSetupHelper()
{
if (string.IsNullOrEmpty(path))
{
string currentDirectory = Directory.GetCurrentDirectory();
path = currentDirectory + "\\LocalSetup.Data";
}
if (!File.Exists(path))
{
FileStream fs = File.Create(path);
fs.Close();
}
json = LoadFromFile(path);
}
#endregion #region 获取
/// <summary>
/// 获取数据
/// </summary>
/// <param name="id">父节点</param>
/// <param name="propertyName">子节点</param>
/// <returns></returns>
public static object GetData(Enum id, string propertyName)
{
return GetDatas(id, propertyName);
}
#endregion #region 保存
/// <summary>
/// 保存数据
/// </summary>
/// <param name="id">父节点</param>
/// <param name="propertyName">子节点名称</param>
/// <param name="propertyValue">子节点值</param>
public static void SetData(Enum id, string propertyName, object propertyValue)
{
SetData(ref json, id, propertyName, propertyValue); }
#endregion #region 移除
/// <summary>
/// 移除
/// </summary>
/// <param name="id">父节点</param>
/// <param name="propertyName">子节点</param>
public static void RemovePropertyName(Enum id, string propertyName = null)
{
Remove(ref json, id, propertyName); }
/// <summary>
/// 清空数据
/// </summary>
public static void ClearData()
{
json = string.Empty;
SaveToFile(path);
}
#endregion #region 内部方法
private static void Add(ref string json, string propertyName, object propertyValue)
{
JObject jsonObj = JObject.Parse(json);
jsonObj.Add(propertyName, JToken.FromObject(propertyValue));
json = jsonObj.ToString();
} private static void Update(ref string json, string propertyName, object propertyValue)
{
JObject jsonObj = JObject.Parse(json);
jsonObj[propertyName] = JToken.FromObject(propertyValue);
json = jsonObj.ToString();
} private static object GetValue(string json, string propertyName)
{
dynamic jsonObj = JsonConvert.DeserializeObject(json);
return jsonObj[propertyName];
} private static void Remove(ref string json, Enum id, string propertyName = null)
{
dynamic jsonObj = JsonConvert.DeserializeObject(json);
if (propertyName == null)
{
jsonObj.Remove(propertyName);
}
else
{
//jsonObj["总台"].Value<JObject>().Remove("账号");
jsonObj[id.ToString()].Remove(propertyName);//13.0版本
}
json = JsonConvert.SerializeObject(jsonObj);
SaveToFile(path);
} private static void SetData(ref string json, Enum id, string propertyName, object propertyValue)
{
JObject jsonObj;
if (!string.IsNullOrEmpty(json))
{
jsonObj = JObject.Parse(json);
}
else
{
jsonObj = new JObject();
} if (jsonObj[id.ToString()] == null)
{
jsonObj.Add(id.ToString(), new JObject());
}
jsonObj[id.ToString()][propertyName] = JToken.FromObject(propertyValue); json = jsonObj.ToString();
SaveToFile(path);
} private static object GetDatas(Enum id, string propertyName)
{
if (!string.IsNullOrEmpty(json))
{
JObject jsonObj = (JObject)JsonConvert.DeserializeObject(json);
JObject frontEndObj = jsonObj[id.ToString()] as JObject;
if (frontEndObj!=null&&frontEndObj.ContainsKey(propertyName))
{
return jsonObj[id.ToString()][propertyName];
}
}
return null;
} private static void SaveToFile(string filePath)
{
using (var fileStream = new FileStream(filePath, FileMode.Create, FileAccess.Write, FileShare.None))
{
using (var streamWriter = new StreamWriter(fileStream))
{
streamWriter.Write(json);
}
}
} private static string LoadFromFile(string filePath)
{
string[] lines = File.ReadAllLines(filePath);
return string.Join("", lines);
}
#endregion
}

当然也有这种节点的

{
"密码": "123456",
"密码xxx": "123456"
}

可以参考前面的连接 :(Newtonsoft)Json增删改查(这是单个对象) - 22222220 - 博客园 (cnblogs.com)

C# Newtonsoft增删改查(本地存储)(简单便捷)(拿来即用)的更多相关文章

  1. 如何创建数据库以及MySQL增删改查命令的简单运用

    在已经安装好MySQL的前提下 1.在Windows打开命令提示符窗口,输入命令启动MySQL命令行工具并登入root用户:mysql -h localhost -u root -p 2.输入密码后, ...

  2. C#中对sqlserver进行增删改查操作(简单易懂)

    1.添加引用using System.Data;using System.Data.SqlData; 2.建立于数据库的连接,建议将它做成一个方法,方便多次利用.string sqlconnectio ...

  3. MyBatis对数据库的增删改查操作,简单演示样例

    之前一直有用Hibernate进行开发.近期公司在使用Mybatis.依据网上的演示样例,做了一个简单的Demo,以便日后复习 使用XMl方式映射sql语句 整体结构例如以下图 watermark/2 ...

  4. easyui+nodejs+sqlserver增删改查实现

    用到的模块或者技术: Express: http://www.expressjs.com.cn/4x/api.html#express Easyui: http://www.jeasyui.com/d ...

  5. QMap 的增删改查

    map 是一种数据容器,它提供一种由key 到 value 的映射.map 的key 是唯一的, 也是有序的.map 通常由近似平衡的红黑树来实现.key 的有序性,使得插入,查找节点比较有效.map ...

  6. MyBatis-单表的增删改查(CRUD)操作

          在学习MyBatis的单表的增删改查操作之前,还是再次熟悉下MyBatis这个框架,只有对其熟悉的情况下,才能很好的使用,灵活的开发.         MyBatis优点:         ...

  7. Spring Date JPA实现增删改查

    1.新建一个Cart类 package com.entity; public class Cart { private int id; private int userId; private int ...

  8. 12 Servlet_04 Servlet增删改查 静态页面与动态页面 EL表达式 table表格的一些样式

    今天学习了servlet的增删改查: 存储数据 setAttribute(String name,Object obj );获取数据 getAttribute(String name);删除数据 re ...

  9. Mybatis-plus实现数据库的增删改查操作

    目录 1.MybatisPlus简介 2.MybatisPlus注解介绍 3.常用方法 4.SpringBoot整合MybatisPlus实现增删改查的一个简单Demo 5.参考资料 1.Mybati ...

  10. 使用Mongoose类库实现简单的增删改查

    使用Mongoose类库实现简单的增删改查 Mongoose是在nodejs环境中对MongoDB数据库操作的封装,一种对象模型工具,可以将数据库中的数据转换为javascript对象供我们使用. M ...

随机推荐

  1. js实现一个拖拽效果(本例vue中),边界限定,获取鼠标坐标,div坐标

    有事没事搞个图: demo: <!DOCTYPE html> <html lang="en"> <head> <meta charset= ...

  2. MO Memory

    关于MO和OI的选拔流程 MO:省赛--联赛--国赛 省赛:各省组织,时间不同但多在4~6月.按成绩选出参加联赛选手.浙江省的省赛全称"浙江省高中数学联赛",5月进行. 联赛:旧称 ...

  3. JDK源码阅读-------自学笔记(十三)(java.text.DateFormat和SimpleDateFormat类)

    时间相关类总图

  4. [第一届长城杯]-ez-python

    ----这道题似曾相识,和某刃的题目不能说不同,简直就一摸一样 ----考点:pickle序列化问题,命令执行 ----正常访问网站,源代码F12给出?pic=的提示,这种大致一看就是可以任意文件访问 ...

  5. P1036 [NOIP2002 普及组] 选数

    传送锚点:https://www.luogu.com.cn/problem/P1036 题目描述 已知 \(n\) 个整数 \(x_1,x_2,\cdots,x_n\),以及 \(1\) 个整数 \( ...

  6. Go的接口与多态

    什么是Go的接口? 接口可以说是一种类型,可以粗略的理解为他的变量是一堆方法. 一个简单的案例: r,_ := http.Get("http://www.baidu.com") i ...

  7. 开源一站式敏捷测试管理,极简项目管理平台 itest(爱测试) 6.6.2 发布,便捷迫切功能增强

    (一)itest 简介及更新说明 itest 开源敏捷测试管理,testOps 践行者,极简的任务管理,测试管理,缺陷管理,测试环境管理,接口测试5合1,又有丰富的统计分析.可按测试包分配测试用例执行 ...

  8. yum install 出错

    ``` yum -y install ansible ``` 出错 一直在刷屏,刚开始以为在安装但是最后没有安装成功 百度发现是这是redhat7和8的yum源混用 1.先确认本机器系统信息 cat ...

  9. Excel相关技巧

    (1)如何实现EXCEL某个单元格满足条件整行变色? 链接:https://jingyan.baidu.com/article/75ab0bcba47c19d6864db2cf.html (2)获取表 ...

  10. kettle从入门到精通 第六十五课 ETL之kettle 执行动态SQL语句,轻松实现全量&增量数据同步

    本次课程的逻辑是同步t1表数据到t2表,t1和t2表的表机构相同,都有id,name,createtime三个字段. CREATE TABLE `t1` ( `id` bigint NOT NULL ...