遍歷指定文件夾下Excel文件,并進行讀取出來

/// <summary>
        /// 遍歷指定文件夾下Excel文件,并進行讀取出來
        /// </summary>
        /// <param name="dirPath">指定文件夾目录</param>
        public void GetExcelInfo(string dirPath)
        {
            //在指定目录及子目录下查找文件,在listBox1中列出子目录及文件
            DirectoryInfo Dir = new DirectoryInfo(dirPath);
            FileAttributes fa;
            try
            {
                foreach (DirectoryInfo d in Dir.GetDirectories())//查找子目录
                {
                    fa = d.Attributes & FileAttributes.Hidden;
                    if (fa == FileAttributes.Hidden)
                    {
                        continue;
                    }
                    fa = d.Attributes & FileAttributes.System;
                    if (fa == FileAttributes.System)
                    {
                        continue;
                    }
                    fa = d.Attributes & FileAttributes.Temporary;
                    if (fa == FileAttributes.Temporary)
                    {
                        continue;
                    }
                    GetExcelInfo(Dir + "\\" + d.ToString() + "\\");
                }
                foreach (FileInfo f in Dir.GetFiles("*.xls")) //查找文件
                {
                    if (f.Name.IndexOf("CARD_DSN_DDS_") > -1)
                    {
                        str_TempList = f.Name.Split('.');
                        s_Temp = str_TempList[0].Replace("CARD_DSN_DDS_", "");
                        if (!hash_ExcelMark.ContainsKey(s_Temp))
                        {
                            FileAttributes MyAttributes = File.GetAttributes(f.FullName);

                            if ((MyAttributes & FileAttributes.System) == FileAttributes.System)
                            {
                                continue;
                            }
                            if ((MyAttributes & FileAttributes.Hidden) == FileAttributes.Hidden)
                            {
                                continue;
                            }
                            if ((MyAttributes & FileAttributes.Temporary) == FileAttributes.Temporary)
                            {
                                continue;
                            }

                            hash_ExcelMark.Add(s_Temp, ExcelClass.GetExcelRemarkForNpoi(f.FullName));
                        }
                    }
                }
                foreach (FileInfo f in Dir.GetFiles("*.xlsx")) //查找文件
                {
                    if (f.Name.IndexOf("CARD_DSN_DDS_") > -1)
                    {
                        str_TempList = f.Name.Split('.');
                        s_Temp = str_TempList[0].Replace("CARD_DSN_DDS_", "");
                        if (!hash_ExcelMark.ContainsKey(s_Temp))
                        {
                            FileAttributes MyAttributes = File.GetAttributes(f.FullName);
                            if ((MyAttributes & FileAttributes.System) == FileAttributes.System)
                            {
                                continue;
                            }
                            if ((MyAttributes & FileAttributes.Hidden) == FileAttributes.Hidden)
                            {
                                continue;
                            }
                            if ((MyAttributes & FileAttributes.Temporary) == FileAttributes.Temporary)
                            {
                                continue;
                            }
                            hash_ExcelMark.Add(s_Temp, ExcelClass.GetExcelRemarkForNpoi(f.FullName));
                        }
                    }
                }
            }
            catch (Exception e)
            {
                MessageBox.Show(e.Message);
            }
        }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
雪山凌狐教程出品,文件遍历器来袭,希望通过源码的分享能跟大家一起学习文件的遍历功能,内涵绝对干货内容和套路可以直接套用! 为了避免不使用线程时界面卡顿,调用了精易模块5.28的线程功能,你不喜欢可以自己去掉或者用上自己写的多线程代码都可。这个关系不大。 其他部分纯源码不涉及其他模块。 软件功能: 1. 首先设定一个要遍历的文件夹,可以设置要遍历文件的后缀名或者不设置,可以选择是否遍历子目录或者只是根目录,进行所有文件的遍历并输出找到的文件文件名,文件完整路径,修改时间,文件大小到超级列表框。 2. 遍历完成后,可以在搜索框输入内容进行即时搜索,请注意是即时的。 3. 可以点击清空清空列表框内容。 4. 可以自动保存和读取配置。(该部分用了模块的批量保存命令,你也可以手动保存) 源代码亮点: 1. 线程调用,界面不卡顿(可以自己改了删掉或者用自己的多线程代码) 2. 新建了一个程序集叫做“程序集_遍历”,里面的“遍历文件”函数可以脱离该源码使用到你任何的程序中,可直接接入性非常高,只需要传入参数即可。 3. 主窗口的函数中有一个函数叫做“时间格式化”,也可以直接脱离该源码直接使用。 4. 当搜索框内容被改变时,如何进行即时搜索并再次显示出来?源码中是一个很好的例子,值得学习。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值