Json.NET读取和写入Json文件

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Web;
  5. using System.Web.UI;
  6. using System.Web.UI.WebControls;
  7. using System.IO;
  8. using System.Text;
  9. using Newtonsoft.Json;
  10. using com.zjpx.model;
  11. using System.Collections;
  12. using Newtonsoft.Json.Converters;
  13. namespace web
  14. {
  15. public partial class testJson : System.Web.UI.Page
  16. {
  17. protected void Page_Load(object sender, EventArgs e)
  18. {
  19. ConfigFileModel cfm = new ConfigFileModel();  //实体模型类
  20. cfm.CreateDate = "2012-02-23";
  21. cfm.FileName = "test.txt";
  22. //可以操作集合
  23. Hashtable ht = new Hashtable();
  24. ht.Add("hs_name", "alex");
  25. ht.Add("hs_pwd", "ggg");
  26. //序列化
  27. string js1 = JsonConvert.SerializeObject(cfm);
  28. string js2 = JsonConvert.SerializeObject(ht);
  29. Response.Write(js1);
  30. Response.Write("<br/>");
  31. Response.Write(js2);
  32. //"{\"FileName\":\"test.txt\",\"CreateDate\":\"2012-02-23\"}"
  33. //"{\"hs_pwd\":\"ggg\",\"hs_name\":\"alex\"}"
  34. //反序列化
  35. ConfigFileModel debc1 = JsonConvert.DeserializeObject<ConfigFileModel>(js1);
  36. ConfigFileModel debc2 = JsonConvert.DeserializeObject<ConfigFileModel>(js2);
  37. //找到服务器物理路径
  38. //string serverAppPath = Request.PhysicalApplicationPath.ToString();
  39. string serverAppPath = @"d:\";
  40. //构成配置文件路径
  41. string con_file_path [email protected]""+ serverAppPath + @"config.json";
  42. if (!File.Exists(con_file_path))
  43. {
  44. File.Create(con_file_path);
  45. }
  46. //把模型数据写到文件
  47. using (StreamWriter sw = new StreamWriter(con_file_path))
  48. {
  49. try
  50. {
  51. JsonSerializer serializer = new JsonSerializer();
  52. serializer.Converters.Add(new JavaScriptDateTimeConverter());
  53. serializer.NullValueHandling = NullValueHandling.Ignore;
  54. //构建Json.net的写入流
  55. JsonWriter writer = new JsonTextWriter(sw);
  56. //把模型数据序列化并写入Json.net的JsonWriter流中
  57. serializer.Serialize(writer, cfm);
  58. //ser.Serialize(writer, ht);
  59. writer.Close();
  60. sw.Close();
  61. }
  62. }
  63. catch (Exception ex)
  64. {
  65. ex.Message.ToString();
  66. }
  67. //读取json文件
  68. using (StreamReader sr = new StreamReader(con_file_path))
  69. {
  70. try
  71. {
  72. JsonSerializer serializer = new JsonSerializer();
  73. serializer.Converters.Add(new JavaScriptDateTimeConverter());
  74. serializer.NullValueHandling = NullValueHandling.Ignore;
  75. //构建Json.net的读取流
  76. JsonReader reader = new JsonTextReader(sr);
  77. //对读取出的Json.net的reader流进行反序列化,并装载到模型中
  78. cfm = serializer.Deserialize<ConfigFileModel>(reader);
  79. Response.Write("<br/>");
  80. Response.Write(cfm.FileName+", "+cfm.CreateDate);
  81. }
  82. catch (Exception ex)
  83. {
  84. ex.Message.ToString();
  85. }
  86. }
  87. }
  88. }
  89. public class ConfigFileModel
  90. {
  91. public ConfigFileModel() { }
  92. string _fileName;
  93. public string FileName
  94. {
  95. get { return _fileName; }
  96. set { _fileName = value; }
  97. }
  98. string _createDate;
  99. public string CreateDate
  100. {
  101. get { return _createDate; }
  102. set { _createDate = value; }
  103. }
  104. }
  105. }
时间: 2024-12-19 10:45:51

Json.NET读取和写入Json文件的相关文章

c/c++中读取和写入mat文件 --- MAT File I/O Library(二)

本篇记述c/c++中读取mat文件示例 测试数据matioTest.zip下载地址: http://pan.baidu.com/s/1sjPkMsd 1. 读取matioTest.zip中s.mat文件,数据为普通matrix 1 #include <iostream> 2 #include <cassert> 3 #include <matio.h> 4 5 6 int main() 7 { 8 mat_t *matfp; 9 const char* matFileP

Asp.net读取和写入txt文件方法(实例)!

Asp.NET读取和写入txt文件方法(实例)! [程序第一行的引入命名空间文件 - 参考] System; using System.Collections; using System.Configuration; using System.Data; using System.Linq; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.HtmlControls; usi

python读取并写入csv文件

新建csvData.csv文件 1 import csv 2 3 # 读取csv文件方式1 4 csvFile = open("csvData.csv", "r") 5 reader = csv.reader(csvFile) # 返回的是迭代类型 6 data = [] 7 for item in reader: 8 print(item) 9 data.append(item) 10 11 print(data) 12 csvFile.close() 13 14

C#读取和写入XML文件

关于xml是属于一个比较重要的东西,在平时开发的过程中,这块内容最主要的是要掌握XML内容的读取和写入操作. 一.什么是XML? XML 指可扩展标记语言(EXtensible Markup Language) XML 是一种标记语言,很类似HTML XML 的设计宗旨是传输数据,而非显示数据 XML 标签没有被预定义,您需要自行定义标签 XML 被设计为具有自我描述性 XML 是W3C 的推荐标准 二.XML语法: 1.一个XML包含以下几部分内容: 文档声明,元素,属性,注释,CDATA(特

python之读取和写入csv文件

写入csv文件源码: 1 #输出数据写入CSV文件 2 import csv 3 data = [ 4 ("Mike", "male", 24), 5 ("Lee", "male", 26), 6 ("Joy", "female", 22) 7 ] 8 9 #Python3.4以后的新方式,解决空行问题 10 with open('d://write.csv', 'w', newline

C#读取并写入XML文件

XML(可扩展标记语言)文件,可以用来标记数据.定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言. XML与HTML的设计区别是:XML 被设计为传输和存储数据,其焦点是数据的内容.而HTML 被设计用来显示数据,其焦点是数据的外观.HTML 旨在显示信息,而 XML 旨在传输信息. XML和HTML语法区别:HTML的标记不是所有的都需要成对出现,XML则要求所有的标记必须成对出现:HTML标记不区分大小写,XML则大小敏感,即区分大小写. 在Asp.Net中我们需要通过C#来对已

C# 创建,读取,写入 XML文件1

XML格式如下 <?xml version="1.0" encoding="utf-8"?> <Advertisements> <Ad> <ImageUrl>001.jpg</ImageUrl> <NavigateUrl>001.aspx</NavigateUrl> <Impressions>10</Impressions> <Keyword>gu

C# 创建,读取,写入 XML文件

XML格式如下 <?xml version="1.0" encoding="utf-8"?><Advertisements>  <Ad>    <ImageUrl>001.jpg</ImageUrl>    <NavigateUrl>001.aspx</NavigateUrl>    <Impressions>10</Impressions>    <K

python读取和写入csv文件

----------------python读取csv文件------------------ #导入csv 创建一个csv文件,输入内容 import csv #1.找到需要被打开的文件路径,通过open打开文件,声明打开的方式,声明编码格式 csv_file=open(r'csv文件路径', mode='r', encoding='utf-8') #2.通过csv模组提供的读取方法来读取打开的文件 csv_data=csv.reader(csv_file) #3.通过for循环遍历读取数据存