DataSet、DataTable、Json、List 等各种数据的相互转化
2015-07-30 09:30
716 查看
1.根据Dataset生成json格式的字符串,不管Dataset里面有多少个表都可以一一生成对应的json字符串,并一次性返回
2.数据库中的内容转换成json数据
3.C# - list<>数据填充到Dataset里
4.DataSet 和 Datable 的相互转化
5.List转化成数组
6.将字符转转化成数组并以逗号分割,即,去掉逗号
7.截取字符转从字符串指定位置截取到固定的长度
private string dsToJson(DataSet ds) { System.Text.StringBuilder str = new System.Text.StringBuilder("["); for (int o = 0; o < ds.Tables.Count; o++) { str.Append("{"); str.Append(string.Format("\"{0}\":[", ds.Tables[o].TableName)); for (int i = 0; i < ds.Tables[0].Rows.Count; i++) { str.Append("{"); for (int j = 0; j < ds.Tables[0].Columns.Count; j++) { str.Append(string.Format("\"{0}\":\"{1}\",", ds.Tables[0].Columns[j].ColumnName, ds.Tables[0].Rows[i][j].ToString())); } str.Remove(str.Length - 1, 1); str.Append("},"); } str.Remove(str.Length - 1, 1); str.Append("]},"); } str.Remove(str.Length - 1, 1); str.Append("]"); return str.ToString(); }
2.数据库中的内容转换成json数据
[WebMethod] [ScriptMethod(ResponseFormat = ResponseFormat.Json)] private string dsToJson() { System.Text.StringBuilder str = new System.Text.StringBuilder("["); for (int o = 0; o < ds.Tables.Count; o++) { str.Append("{"); str.Append(string.Format("\"{0}\":[", ds.Tables[o].TableName)); for (int i = 0; i < ds.Tables[0].Rows.Count; i++) { str.Append("{"); for (int j = 0; j < ds.Tables[0].Columns.Count; j++) { str.Append(string.Format("\"{0}\":\"{1}\",", ds.Tables[0].Columns[j].ColumnName, ds.Tables[0].Rows[i][j].ToString())); } str.Remove(str.Length - 1, 1); str.Append("},"); } str.Remove(str.Length - 1, 1); str.Append("]},"); } str.Remove(str.Length - 1, 1); str.Append("]"); return str.ToString(); }
3.C# - list<>数据填充到Dataset里
publicstatic DataSet ConvertToDataSet<T>(IList<T> list) { if (list ==null|| list.Count <=0) { returnnull; } DataSet ds =new DataSet(); DataTable dt =new DataTable(typeof(T).Name); DataColumn column; DataRow row; System.Reflection.PropertyInfo[] myPropertyInfo =typeof(T).GetProperties(System.Reflection.BindingFlags.Public | System.Reflection.BindingFlags.Instance); foreach (T t in list) { if (t ==null) { continue; } row = dt.NewRow(); for (int i =0, j = myPropertyInfo.Length; i < j; i++) { System.Reflection.PropertyInfo pi = myPropertyInfo[i]; string name = pi.Name; if (dt.Columns[name] ==null) { column =new DataColumn(name, pi.PropertyType); dt.Columns.Add(column); } row[name] = pi.GetValue(t, null); } dt.Rows.Add(row); } ds.Tables.Add(dt); return ds; } }
4.DataSet 和 Datable 的相互转化
DataSet ds = DbHelperSQL.Query("select * from text_table where a='3'"); string strtext = ds.Tables[0].Rows[0]["bz"].ToString();
5.List转化成数组
List<string> a = new List<string>(); public string[] getString(TreeNodeCollection item) { NumMethod(item); return a.ToArray(); }
6.将字符转转化成数组并以逗号分割,即,去掉逗号
string strszcdid = "1111,111111,111112,111211,111311,"; string[] a = strszcdid.Split(',');
7.截取字符转从字符串指定位置截取到固定的长度
id = id.Substring(0, id.Length - 1);
相关文章推荐
- 理解javascript中的原型和原型链
- 用json实现服务器servlet和安卓客户端的数据交互
- 实现跨域cookie共享
- javascript设计模式之Module模块
- Javascript Array操作函数整理
- JavaScript学习14:表单处理
- js中cookie的使用详细分析
- Javascript操作iframe
- javascript 语言精粹 笔记推荐。。
- Javascript中理解发布--订阅模式
- javaScript之function定义
- js代码实现微博导航栏
- 理解javascript中的原型和原型链
- 用javascript实现自动输出网页文本
- javascript中if和switch,==和===详解
- js判断浏览器类型及设备(移动页面开发)
- javascript设计模式之对象工厂函数与构造函数详解
- js代码验证手机号码和电话号码是否合法
- js代码实现随机颜色的小方块
- JS如何实现文本框随文本的长度而增长