- 浏览: 435669 次
- 性别:
- 来自: 唐山
文章分类
最新评论
-
hautbbs:
谢谢分享!
ASP.NET 导出Excel 和csv -
hautbbs:
感谢分享!
ASP.NET 导出Excel乱码的终极解决 -
wyf:
zcl920 写道只能说 看不懂。要发就发全 取一段出来 有什 ...
图片上绘制文字换行处理 -
zcl920:
只能说 看不懂。要发就发全 取一段出来 有什么用。
图片上绘制文字换行处理 -
380086154:
有用,谢谢。
js比较日期
/// <summary> /// 泛型集合与DataSet互相转换 /// </summary> public class IListDataSet { /// <summary> /// 集合装换DataSet /// </summary> /// <param name="list">集合</param> /// <returns></returns> /// 2008-08-01 22:08 HPDV2806 public static DataSet ToDataSet( IList p_List ) { DataSet result = new DataSet(); DataTable _DataTable = new DataTable(); if ( p_List.Count > 0 ) { PropertyInfo[] propertys = p_List[0].GetType().GetProperties(); foreach ( PropertyInfo pi in propertys ) { _DataTable.Columns.Add( pi.Name, pi.PropertyType ); } for ( int i = 0; i < p_List.Count; i++ ) { ArrayList tempList = new ArrayList(); foreach ( PropertyInfo pi in propertys ) { object obj = pi.GetValue( p_List[i], null ); tempList.Add( obj ); } object[] array = tempList.ToArray(); _DataTable.LoadDataRow( array, true ); } } result.Tables.Add( _DataTable ); return result; } /// <summary> /// 泛型集合转换DataSet /// </summary> /// <typeparam name="T"></typeparam> /// <param name="list">泛型集合</param> /// <returns></returns> /// 2008-08-01 22:43 HPDV2806 public static DataSet ToDataSet<T>( IList<T> list ) { return ToDataSet<T>( list, null ); } /// <summary> /// 泛型集合转换DataSet /// </summary> /// <typeparam name="T"></typeparam> /// <param name="p_List">泛型集合</param> /// <param name="p_PropertyName">待转换属性名数组</param> /// <returns></returns> /// 2008-08-01 22:44 HPDV2806 public static DataSet ToDataSet<T>( IList<T> p_List, params string[] p_PropertyName ) { List<string> propertyNameList = new List<string>(); if ( p_PropertyName != null ) propertyNameList.AddRange( p_PropertyName ); DataSet result = new DataSet(); DataTable _DataTable = new DataTable(); if ( p_List.Count > 0 ) { PropertyInfo[] propertys = p_List[0].GetType().GetProperties(); foreach ( PropertyInfo pi in propertys ) { if ( propertyNameList.Count == 0 ) { // 没有指定属性的情况下全部属性都要转换 _DataTable.Columns.Add( pi.Name, pi.PropertyType ); } else { if ( propertyNameList.Contains( pi.Name ) ) _DataTable.Columns.Add( pi.Name, pi.PropertyType ); } } for ( int i = 0; i < p_List.Count; i++ ) { ArrayList tempList = new ArrayList(); foreach ( PropertyInfo pi in propertys ) { if ( propertyNameList.Count == 0 ) { object obj = pi.GetValue( p_List[i], null ); tempList.Add( obj ); } else { if ( propertyNameList.Contains( pi.Name ) ) { object obj = pi.GetValue( p_List[i], null ); tempList.Add( obj ); } } } object[] array = tempList.ToArray(); _DataTable.LoadDataRow( array, true ); } } result.Tables.Add( _DataTable ); return result; } /// <summary> /// DataSet装换为泛型集合 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="p_DataSet">DataSet</param> /// <param name="p_TableIndex">待转换数据表索引</param> /// <returns></returns> /// 2008-08-01 22:46 HPDV2806 public static IList<T> DataSetToIList<T>( DataSet p_DataSet, int p_TableIndex ) { if ( p_DataSet == null || p_DataSet.Tables.Count < 0 ) return null; if ( p_TableIndex > p_DataSet.Tables.Count - 1 ) return null; if ( p_TableIndex < 0 ) p_TableIndex = 0; DataTable p_Data = p_DataSet.Tables[p_TableIndex]; // 返回值初始化 IList<T> result = new List<T>(); for ( int j = 0; j < p_Data.Rows.Count; j++ ) { T _t = (T)Activator.CreateInstance( typeof( T ) ); PropertyInfo[] propertys = _t.GetType().GetProperties(); foreach ( PropertyInfo pi in propertys ) { for ( int i = 0; i < p_Data.Columns.Count; i++ ) { // 属性与字段名称一致的进行赋值 if ( pi.Name.Equals( p_Data.Columns[i].ColumnName ) ) { // 数据库NULL值单独处理 if ( p_Data.Rows[j][i] != DBNull.Value ) pi.SetValue( _t, p_Data.Rows[j][i], null ); else pi.SetValue( _t, null, null ); break; } } } result.Add( _t ); } return result; } /// <summary> /// DataSet装换为泛型集合 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="p_DataSet">DataSet</param> /// <param name="p_TableName">待转换数据表名称</param> /// <returns></returns> /// 2008-08-01 22:47 HPDV2806 public static IList<T> DataSetToIList<T>( DataSet p_DataSet, string p_TableName ) { int _TableIndex = 0; if ( p_DataSet == null || p_DataSet.Tables.Count < 0 ) return null; if ( string.IsNullOrEmpty( p_TableName ) ) return null; for ( int i = 0; i < p_DataSet.Tables.Count; i++ ) { // 获取Table名称在Tables集合中的索引值 if ( p_DataSet.Tables[i].TableName.Equals( p_TableName ) ) { _TableIndex = i; break; } } return DataSetToIList<T>( p_DataSet, _TableIndex ); } } 本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/veryhappy/archive/2008/08/04/2764333.aspx
利用反射机制将DataTable的字段与自定义类型的公开属性互相赋值。注意:从DataSet到IList<T>的转换,自定义类型的公开属性必须与DataTable中的字段名称一致,才能到达想要的结果。建议DataTable的定义从数据库来,自定义类型用O/R Mapping的方式获得。
发表评论
-
登录时记住用户名密码的实现方式
2019-06-12 15:11 3032登录的时候记住用户 ... -
CAS 实现单点登录 .NET MVC
2016-05-24 17:14 1130http://www.cnblogs.com/woxpp/p ... -
.NET开发邮件发送功能的全面教程(含邮件组件源码)
2015-03-31 09:43 1169原文地址:http://www.cnblogs.com/he ... -
开发Web组合
2015-01-04 11:39 6131、数据库操作 ORM-Dapper 2、前台界面布局采 ... -
基于 Bootstrap 构建的网站
2014-12-14 14:12 636文档,下载地址:http://v3.bootcss.com ... -
iis8 默认不支持svc解决方法
2014-09-18 18:57 781以下内容对于使用WIN2012 部署V9的时候使用。 ... -
C# 连接Oracle(利用ODP.net,不安装oracle客户端)
2014-07-11 09:37 1696C# 连接Oracle(利用ODP.net,不安装oracl ... -
C# Attribute 特性,过期特性
2014-05-27 15:18 1844通过下列过程将属性应用到代码元素。 通过从 .NE ... -
.NET画实时直方图
2011-12-30 09:37 918using System; using System.Col ... -
设置combobx选中项
2011-12-21 15:20 1033cbRole.SelectedIndex = cbRole.I ... -
文档树状结构化目录管理方法
2011-12-20 09:50 2190本文适用于附件(各类文档、图片和压缩包等,下同)比较多的 ... -
.StringTemplate替换模板
2011-11-03 10:19 1247官方下载 www.StringTemplate. ... -
WCF-IErrorHandler
2011-10-11 16:30 1053使用 IErrorHandler 接口,我们可以更深入地 ... -
ADODB.Stream instead of Scripting.FileSystemObject.
2011-07-04 08:55 1241In a Silverlight 4 OOB App (eve ... -
Scripting.FileSystemObject对象的详细技巧指南
2011-07-03 23:39 1047Scripting.FileSystemObject对象的 ... -
Stream 和 byte[] 之间的转换
2011-07-02 16:52 1071/* - - - - - - - - - - - - - ... -
常用正则表达式
2011-06-15 20:17 794正则表达式用于字符 ... -
DynamicMethod 类
2011-05-11 22:51 1164public delegate String MyMetho ... -
一个通用的快速反射方法(A General Fast Method Invoker)
2011-04-13 22:01 1526普通反射方法 MethodInfo methodIn ... -
C#操作IIS(转)可以写一个工具自己配置网站
2011-03-24 21:08 2269using System; using System.Dir ...
相关推荐
对比`List泛型`和`DataSet`,前者更适用于简单、类型安全的数据操作,而后者更适合处理复杂的离线数据,特别是当数据与数据库紧密关联时。在实际开发中,根据具体需求选择合适的数据结构是非常关键的。 总结起来,`...
`DataSet`是一个内存中的数据集合,可以包含多个`DataTable`,它们之间可以通过`DataRelation`建立关联。而`XML`是一种可扩展标记语言,常用于数据交换、配置存储等场景。在实际开发中,我们经常需要在`DataSet`和`...
本篇文章主要探讨如何在C#中通过使用`DataSet`对象来读取数据库,并将其转换为泛型集合,如`List<T>`。 首先,我们来看一个基本的示例代码,它演示了如何从数据库获取数据并将其绑定到一个`GridView`控件上。`Page_...
在IT领域,尤其是在软件开发与数据处理中,将数据集(如`Dataset`)转换为实体集合是一项常见的需求。这通常涉及到将从数据库查询或数据源获取的数据转换为应用程序可以更方便操作的对象形式。给定的代码片段展示了...
三、DataSet与XML的转换 1. `DataSet`转XML: - `DataSet.WriteXml()`: 这是将`DataSet`写入XML文件的主要方法。例如: ```csharp dataSet.WriteXml("dataset.xml", XmlWriteMode.WriteSchema); ``` 参数`...
在asp.net中提供了数据集DateSet与Xml转换的类 XmlDatasetConvert code: XmlDatasetConvert 该类提供了四种方法: 1、将xml对象内容字符串转换为DataSet 2、将xml文件转换为DataSet 3、将DataSet转换为...
在C#编程中,经常需要在`DataSet`和XML文件之间进行转换,以便于数据的持久化、跨平台传输或与其他系统集成。下面我们将详细探讨这两种数据结构之间的转换过程。 1. `DataSet`到XML的转换: 当你需要将`DataSet`的...
将查询来的DataSet转成JSon形式,接收时注意,string和int字段都是用String形式的接受
本篇将详细讲解如何在`DataSet`与`Byte[]`之间进行转换,并涉及数据压缩的相关知识。 1. `DataSet`转`Byte[]`: 当我们需要将`DataSet`的内容保存到磁盘或者通过网络发送时,可以将其转换为`Byte[]`。这通常通过...
`DataSet`与XML之间的转换是.NET开发中的常见操作,这使得数据能够在不同的系统间无缝传递。本文将深入探讨`DataSet`与XML的相互转换方法及其应用场景。 首先,`DataSet`到XML的转换主要通过`DataSet.WriteXml`方法...
### DataSet 转化为 List 的通用方法:深入解析与应用 在 IT 领域,数据处理是一项核心任务,特别是在数据库操作与数据展现层之间,数据格式的转换显得尤为重要。其中,`DataSet`到`List`的转换是常见的需求之一,...
delphi 下把数据源dataset转换为json字符串,然后通过三层下发或者上传!
标题 "DataSetConverter4D 演示程序源代码" 提供了一个关键的线索,即这是一个与数据集转换相关的开源项目,特别关注如何将数据集(DataSet)转换为JSON格式。描述进一步确认了这一点,提到了"Format_JSON"函数的源...
在给定的部分代码中,我们看到一个名为`ListToDataSet`的方法,其功能是将一个泛型列表转换为`DataSet`对象。下面是对这段代码的逐行分析: ```csharp private DataSet ListToDataSet(List<object> list) { ...
XML与DataSet的相互转换类 XML与DataSet是两种不同的数据存储和交换格式,XML是一种 Markup Language,用来存储和交换数据,而DataSet是一种数据结构,用于存储和操作数据。为了实现这两种格式之间的互操作,需要有...
C#将对象数组转换成DataSet使用案例 本文将介绍如何将对象数组转换成DataSet,解决了在ASP.NET 2.0 beta 2开发项目中遇到的问题,即将对象数组绑定到GridView的数据源上,但GridView不支持对象数组的排序,因为...
本教程将详细阐述如何在C#中进行XML与DataSet之间的转换,这对于数据的存储、传输和操作至关重要。 XML是一种结构化的数据格式,它独立于任何特定的编程语言,可用于描述和交换数据。DataSet是.NET框架中的一个对象...
### 一、理解DataSet与JSON #### DataSet `DataSet`是.NET框架中用于存储和操作数据的一种对象,它提供了类似数据库的特性,如表、关系和约束等。在客户端和服务器之间传输数据时,`DataSet`可以扮演中间角色,确保...
在IT行业中,JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,广泛用于Web服务与客户端之间的数据传输。...通过实践,你可以更好地掌握JSON与C#数据结构间的转换,并能灵活地应用在各种场景中。
DataSet转换为Excel