【实例应用】DATATable那些事儿

2024-05-25 11:58
文章标签 应用 实例 事儿 datatable

本文主要是介绍【实例应用】DATATable那些事儿,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

      这几天做成绩分析,天天跟DataTable混在一起,应用了其众多属性和方法。今天,就来八一八DataTable那些常用的方法。


一、去除重复行的操作

   在项目中,经常会对表进行固定列的去重操作,此方法就是去除PaperID和PaperName的重复行,并返回这两列:

DataTable dtOld = DataTable();    
//…
DataView myDataView = new DataView(dtOld);//去掉重复行的DataView,dtOld为需要转换的表
DataTable dtDistinct = myDataView.ToTable(true, new string[] { "PaperID", "PaperName" });//DataView的ToTable(true,字段)方法是去掉重复的数据
//第一个参数,true 去除重复,false 不去除//第二个参数, 需要显示并去重的字段,这里用的paperID和PaperName


二、合并两个结构相同的表

   dtOld,dtNew分别是两个结构相同的非空表,把两个表合并成一个表为:

//Merge dtOld into dtNew
dtNew.Merge(dtOld);


三、DataTable进行数据统计

   我们可以轻松的使用SQL Sever进行数据统计,同样,也可以对检索出来的DataTable进行数据统计,我们可以通过函数Compute进行统计。

   1、函数说明

   public object Compute(string strExpression,string strFilter);

   strExpression:要计算的表达式字符串,基本上类似于Sql Server中的统计表达式。

   strFilter:统计的过滤字符串,只有满足这个过滤条件的记录才会被统计。

   

   2、实例

   假设得到如下表dtSport:

   


   1)统计所有得分为零的数量:

   object n=dtSport.Compute("count(ID)","Score=0");


   2)统计各项的平均得分

   decimal averScore=Convert.ToDecimal(dtSport.Compute("avg(Score)","true"));


   3)所有项目的总分

   int intAll = Convert.ToInt32(dtSport.Compute("sum(Score)","true"));


四、动态筛选信息并添加到新表中

   已知datatable表dtSport(如上图),在此以筛选得分大于2分的记录为例:

DataTable dtFilter = new DataTable();
dtFilter = dtSport.Clone();    //得到数据结构和dtSport相同的表
//dtSport.Copy();     得到和dtSport相同的表for (int i = 0; i < dtSport.Rows.Count; i++)
{DataRow[] dr = dtSport.Select("Score>'2' ");if (dr != null && dr.Length > 0){//显示有记录dtFilter.ImportRow(dr[0]);    //得到满足条件的datatable  dtFilter}
}

   DataTable还有许多常用的方法,在此就不一一举例了,熟练的掌握这些方法,能让我们更快更好的完成学习任务,在实践中慢慢积累吧。

 





   

这篇关于【实例应用】DATATable那些事儿的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1001444

相关文章

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

Java操作ElasticSearch的实例详解

《Java操作ElasticSearch的实例详解》Elasticsearch是一个分布式的搜索和分析引擎,广泛用于全文搜索、日志分析等场景,本文将介绍如何在Java应用中使用Elastics... 目录简介环境准备1. 安装 Elasticsearch2. 添加依赖连接 Elasticsearch1. 创

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

Linux中Curl参数详解实践应用

《Linux中Curl参数详解实践应用》在现代网络开发和运维工作中,curl命令是一个不可或缺的工具,它是一个利用URL语法在命令行下工作的文件传输工具,支持多种协议,如HTTP、HTTPS、FTP等... 目录引言一、基础请求参数1. -X 或 --request2. -d 或 --data3. -H 或

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

Oracle Expdp按条件导出指定表数据的方法实例

《OracleExpdp按条件导出指定表数据的方法实例》:本文主要介绍Oracle的expdp数据泵方式导出特定机构和时间范围的数据,并通过parfile文件进行条件限制和配置,文中通过代码介绍... 目录1.场景描述 2.方案分析3.实验验证 3.1 parfile文件3.2 expdp命令导出4.总结

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

java中VO PO DTO POJO BO DO对象的应用场景及使用方式

《java中VOPODTOPOJOBODO对象的应用场景及使用方式》文章介绍了Java开发中常用的几种对象类型及其应用场景,包括VO、PO、DTO、POJO、BO和DO等,并通过示例说明了它... 目录Java中VO PO DTO POJO BO DO对象的应用VO (View Object) - 视图对象