| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1773 人关注过本帖
标题:如何删除csv表格中的重复行
只看楼主 加入收藏
wyh1988
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2011-4-18
结帖率:0
收藏
已结贴  问题点数:20 回复次数:2 
如何删除csv表格中的重复行
我有一个csv表格,如下:
图片附件: 游客没有浏览图片的权限,请 登录注册

我想实现这样的功能,通过第一列的数据来判断是否有重复项,如果有则删除重复项所在的行,最后得到的数据为
图片附件: 游客没有浏览图片的权限,请 登录注册

用C#语言怎么样实现啊,最好有详细的代码,谢谢各位了!
搜索更多相关主题的帖子: 如何 最好 
2015-10-21 16:14
leisiege
Rank: 4
等 级:业余侠客
威 望:8
帖 子:95
专家分:235
注 册:2015-10-22
收藏
得分:20 
读取一行,然后加入到list<string[]>列表中,然后读取下一行,如果list<string[]>中第一列contain读入数据的第一部分。这条数据就不加进去。就ok了。
2015-10-22 15:35
leisiege
Rank: 4
等 级:业余侠客
威 望:8
帖 子:95
专家分:235
注 册:2015-10-22
收藏
得分:0 
程序代码:
namespace ConsoleApplication4
{
    class Program
    {
        static string path = @"C:\Users\鸣\Desktop\1111.csv";
        static void Main(string[] args)
        {
            
            if (File.Exists(path))
            {
                File.Delete(path);
                GenerateFIle();
            }
            List<string[]> content = new List<string[]>();

            ReadFile(content);
            int count = 0;
            foreach (var line in content)
            {
                count++;
                Console.WriteLine(line[0]+','+line[1]+"count:"+count);
            }
            Console.ReadKey();
                

           
            
        }

        private static void ReadFile(List<string[]> content)
        {
            using (StreamReader sr = new StreamReader(path))
            {
                while (true)
                {
                    var line = sr.ReadLine();
                    if (line == null)
                        break;
                    string[] words = line.Split(',');
                    List<string> firstline = content.Select(p => p[0]).ToList();
                    if (!firstline.Contains(words[0]))
                    {
                        content.Add(words);
                    }
                }
            }
        }

        private static void GenerateFIle()
        {
            using (StreamWriter sw = new StreamWriter(path))
            {
                var count = 0;
                Random rnd = new Random();
                for (var i = 0; i < 100; i++)
                {
                    count++;
                    sw.WriteLine(count + "," + rnd.Next(1, 100));
                }
                count = 0;
                for (var i = 0; i < 100; i++)
                {
                    count++;
                    sw.WriteLine(count + "," + rnd.Next(1, 100));
                }
            }
        }

        
    }
}
2015-10-22 15:50
快速回复:如何删除csv表格中的重复行
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.058484 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved