调用方法:
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. 最近常用的几个【行操作】的Pandas函数

    最近在做交易数据的统计分析时,多次用到数据行之间的一些操作,对于其中的细节,简单做了个笔记. 1. shfit函数 shift函数在策略回测代码中经常出现,计算交易信号,持仓信号以及资金曲线时都有涉及 ...

  2. Docker部署Scrapy-redis分布式爬虫框架(整合Selenium+Headless Chrome网页渲染)

    前言 我的京东价格监控网站需要不间断爬取京东商品页面,爬虫模块我采用了Scrapy+selenium+Headless Chrome的方式进行商品信息的采集. 由于最近爬虫用的服务器到期,需要换到新服 ...

  3. sqli-labs-master 第十一关

    本关为POST请求: 输入:admin'# 密码:随意 爆出当前数据库: 用户名:payload1:admin' and extractvalue(1,concat(0x7e,database(),0 ...

  4. 飞桨PaddleLite架构研读

    一.架构全景图 二.源码详细解读 1. Lite体系下似乎有多种 op_desc/program_desc 的定义,之间的关系是什么?这样设计的背景和好处是什么? model_parser目录下,包含 ...

  5. pageoffice6 版本实现在线打开word 文件禁止保存、禁止另存、禁止打印的需求

    在实际项目需求中,有时需要限制用户的保存.另存.打印文件操作,实现此效果只需在OnPageOfficeCtrlInit或AfterDocumentOpened事件中调用js设置PageOffice控件 ...

  6. python 源

    清华:https://pypi.tuna.tsinghua.edu.cn/simple 阿里云:http://mirrors.aliyun.com/pypi/simple/ 中国科技大学 https: ...

  7. RESTful风格openapi接口设计+openapi远程服务调用

    我们平常开发一般只使用GET.POST方法.而对于HTTP给出的PUT.DELETE等其他方法都没使用.以RESTful风格设计接口就能全部用上这些方法. 按照RESTful理查德森成熟度模型改造接口 ...

  8. Python作图三维等高面

    技术背景 对于等高线,大家都是比较熟悉的,因为日常生活中遇到的山体和水面,都可以用一系列的等高线描绘出来.而等高面,顾名思义,就是在三维空间"高度一致"的曲面.当然了,在二维平面上 ...

  9. 腾讯面试:如何提升Kafka吞吐量?

    Kafka 是一个分布式流处理平台和消息系统,用于构建实时数据管道和流应用.它最初由 LinkedIn 开发,后来成为 Apache 软件基金会的顶级项目. Kafka 特点是高吞吐量.分布式架构.支 ...

  10. 未能加载文件或程序集“UFIDA.U8.UAP.GcRegister, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null”或它的某一个依赖项

    这是做采购入库单新增的时候遇到的问题,我是采用模仿写用友u8的zpurrkdhead 主表视图和子表视图zpurrkdtail 去构建 xml文档这样做的,但是再做的时候 [cgcroutecode] ...