获取对固定列不重复的新DataTable

简介: #region 获取对固定列不重复的新DataTable/// <summary> /// 获取对固定列不重复的新DataTable /// </summary> /// <param name="dt">含有重复数据的DataTable</param> /// <param name="colName">需要验
#region 获取对固定列不重复的新DataTable
/// <summary>  
/// 获取对固定列不重复的新DataTable  
/// </summary>  
/// <param name="dt">含有重复数据的DataTable</param>  
/// <param name="colName">需要验证重复的列名</param>  
/// <returns>新的DataTable,colName列不重复,表格式保持不变</returns>  
private DataTable GetDistinctTable(DataTable dt, string colName)  
{  
    if (dt.Rows.Count == 0 || dt.Rows.Count == 1)  
    {  
        WriteFile("GetDistinctTable传入dt的行数小于等于1" + "\r\n", logName, out outMessage);  
        return dt;  
    }  
    DataView dv = dt.DefaultView;  
    //dv过滤dv中的重复列名  
    DataTable dtCardNo = dv.ToTable(true, colName);  
    DataTable Pointdt = new DataTable();  
    //ToTable()根据现有 DataView 中的行,创建并返回一个新的 DataTable。  
    //输出表与输入表包含相同的列  
    Pointdt = dv.ToTable();  
    Pointdt.Clear();  
    for (int i = 0; i < dtCardNo.Rows.Count; i++)  
    {  
        try  
        {  
            //dr取的是Select返回的DataRow[]中的第一条数据  
            //如果dtCardNo.Rows[i][0].ToString()中没有值会报数组超出索引界限的错误  
            if (!string.IsNullOrEmpty(dtCardNo.Rows[i][0].ToString()))  
            {  
               DataRow dr = dt.Select(colName + "='" + dtCardNo.Rows[i][0].ToString() + "'")[0];  
                //DataRow.ItemArray通过一个数组来获取或设置此行的所有值  
                Pointdt.Rows.Add(dr.ItemArray);  
            }  
        }  
        catch (Exception ee)  
        {  
           //可以将错误写入日志文件  
        }  
    }  
    return Pointdt;  
}  
#endregion  




linqs实现

http://blog.csdn.net/jiankunking/article/details/42749663

目录
相关文章
|
存储 Python 容器
`click`是一个用于构建命令行接口的Python包,它提供了简单、可组合的命令行解析器。
`click`是一个用于构建命令行接口的Python包,它提供了简单、可组合的命令行解析器。
|
Python
python文件对象写入文件
【6月更文挑战第7天】
130 6
|
Oracle 安全 Java
Spring Boot 3.0 正式发布,王炸!!
Spring Boot 3.0 正式发布,王炸!!
296 0
Spring Boot 3.0 正式发布,王炸!!
|
机器学习/深度学习 人工智能 算法
【NeurIPS 2019演讲解读】Yoshua Bengio:如何用深度学习来实现System2?
图灵奖得主Yoshua Bengio在NeurIPS 2019的报告提到了几个非常有意思的观点,例如,人的认知系统包含两个子系统,system1直觉系统和system2逻辑分析系统,并解释了如何用深度学习来实现system2。本文带来清华大学唐杰教授对Bengio报告的重新解读。
537 0
【NeurIPS 2019演讲解读】Yoshua Bengio:如何用深度学习来实现System2?
|
JavaScript 前端开发 算法
【JSConf EU 2018】WebAssembly 的手工艺术
在今年欧洲的JSConf上Emil Bay进行了一场题为《Hand-Crafting WebAssembly》的演讲。Emil表示:“现在已经有很多关于WebAssembly(WASM)的演讲。遗憾的是,大多数演讲是关于如何把高级语言编译成wasm的,他们把wasm当成一个半透明的盒子。
2383 0
|
7天前
|
存储 关系型数据库 分布式数据库
PostgreSQL 18 发布,快来 PolarDB 尝鲜!
PostgreSQL 18 发布,PolarDB for PostgreSQL 全面兼容。新版本支持异步I/O、UUIDv7、虚拟生成列、逻辑复制增强及OAuth认证,显著提升性能与安全。PolarDB-PG 18 支持存算分离架构,融合海量弹性存储与极致计算性能,搭配丰富插件生态,为企业提供高效、稳定、灵活的云数据库解决方案,助力企业数字化转型如虎添翼!
|
6天前
|
存储 人工智能 Java
AI 超级智能体全栈项目阶段二:Prompt 优化技巧与学术分析 AI 应用开发实现上下文联系多轮对话
本文讲解 Prompt 基本概念与 10 个优化技巧,结合学术分析 AI 应用的需求分析、设计方案,介绍 Spring AI 中 ChatClient 及 Advisors 的使用。
314 130
AI 超级智能体全栈项目阶段二:Prompt 优化技巧与学术分析 AI 应用开发实现上下文联系多轮对话
|
18天前
|
弹性计算 关系型数据库 微服务
基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
1330 8