最近公司做了一个微信红包的项目,其中一个主要的工作内容是 将238万张券导入到微信平台里面,用于微信卡券的领取和核销.
但是提供给我的券都是以一个个的excel文件给到的.然后通过excel文件的导入功能,将所有的券导入到某张表里.
由于有238万张券,所以一共给到的excel文件大概有100多份.如果是一个个的导入的话,实在太麻烦了.所以,想做一个运用,
将多个excel文件的合并成一个文件. 网上百度了一下,也的确有这样的运用软件.但是有些要么不是免费,要么有些免费但功能受限的.
所以决定还是自己手写一个吧.正好最近也学了微软的WPF,就用它来练习一下学习的成果.

1 开发环境
win7
.net framework 4.0
vs2010 sp1

NuGet

2 功能需求
选择某个文件夹,将该文件夹里面的所有的excel文件都获取出来并在画面上显示.
然后用户可以选择其中的某些文件合并成,并且可以取消操作.

3 实现说明
根据需求分析,可以大概知道具有以下的功能点
3-1 选择文件夹
System.Windows.Forms.FolderBrowserDialog fb = new System.Windows.Forms.FolderBrowserDialog();
if (fb.ShowDialog() == System.Windows.Forms.DialogResult.OK)
{
  //选择的文件夹路径
  selectedPath = fb.SelectedPath + "/";
}

3-2 递归获取excel文件并且显示在listbox控件上
// 声明excel文件的list
private List<ExcelFile> excelFileList = new List<ExcelFile>();
// 递归获取函数
private void FindFile(string dirPath) //参数dirPath为指定的目录
{
  //在指定目录及子目录下查找文件
  DirectoryInfo Dir=new DirectoryInfo(dirPath);
  try
  {
    foreach(DirectoryInfo d in Dir.GetDirectories())//查找子目录
    {
      FindFile(d.FullName);
    }
    foreach(FileInfo f in Dir.GetFiles("*.xls")) //查找文件
    {
      excelFileList.Add(new ExcelFile { Name = f.Name, Path = f.FullName, IsSelected = true, Status="未处理" });
    }
  }
  catch(Exception e)
  {
    MessageBox.Show(e.Message);
  }
}
// 数据绑定
listBox1.ItemsSource = excelFileList;

3-3 用户可选excel文件
改写了listboxItem的template,将一个checkbox放入其中
<ListBox HorizontalAlignment="Stretch" Margin="12,14,12,0" Name="listBox1" VerticalAlignment="Stretch" HorizontalContentAlignment="Stretch" Grid.Row="2" MinHeight="180" MinWidth="480" VerticalContentAlignment="Stretch">
<ListBox.ItemTemplate>
<DataTemplate>
  <Grid Margin="3">
    <Grid.ColumnDefinitions>
      <ColumnDefinition Width="Auto"></ColumnDefinition>
      <ColumnDefinition Width="Auto"></ColumnDefinition>
      <ColumnDefinition Width="*"></ColumnDefinition>
      <ColumnDefinition Width="Auto"></ColumnDefinition>
    </Grid.ColumnDefinitions>
    <CheckBox Grid.Column="0" Padding="3" VerticalAlignment="Center" IsChecked="{Binding Path=IsSelected,Mode=TwoWay}"></CheckBox>
    <TextBlock Grid.Column="1" Padding="5" VerticalAlignment="Center" Text="{Binding Path=Name}"></TextBlock>
    <TextBlock Grid.Column="2" Padding="6" VerticalAlignment="Center" Text="{Binding Path=Path}"></TextBlock>
    <TextBlock Grid.Column="3" Padding="3" VerticalAlignment="Center" Text="{Binding Path=Status}"></TextBlock>
  </Grid>
</DataTemplate>
</ListBox.ItemTemplate>
</ListBox>

3-4 合并excel文件,并且能取消合并的操作
由于读取一个个excel文件的内容最后写入到一个文件中的操作,是很花时间的操作.所以是通过多线程的方式来实现.主要是用到了BackgroundWorker组件.
public static bool merge(string selectedPath, List<ExcelFile> excelFileList, System.ComponentModel.BackgroundWorker backgroundWorker)
{
  // Start the search for primes and wait.
  var writer = new StreamWriter(selectedPath + "all.csv", false, System.Text.Encoding.UTF8);
  writer.WriteLine("券码,券密码,活动说明,有效开始日期,有效结束日期,是否已导入,卡券ID,自定义code");

  int i = 0;
  foreach (var f in excelFileList)
  {
    i++;
    if (backgroundWorker.CancellationPending)
    {
      // Return without doing any more work.
      return false;
    }

    if (backgroundWorker.WorkerReportsProgress)
    {
      backgroundWorker.ReportProgress(i);
    }

    if (!f.IsSelected) continue;
    f.Status = "处理中";
    var stream = new FileStream(f.Path, FileMode.Open);
    IExcelDataReader excelReader = ExcelReaderFactory.CreateOpenXmlReader(stream);
    excelReader.Read();
    while (excelReader.Read())
    {
      var code = (excelReader.GetString(1).Trim());
      var pwd = (excelReader.GetString(2).Trim());
      var activity = (excelReader.GetString(3).Trim());

      if (!string.IsNullOrEmpty(code))
      {
        var card_id = "pgW8rt3XXByGetZUJVlv1bbLuqdk";
        var card_code = code + pwd;
        writer.WriteLine("{0},{1},{2},2015-02-19 00:00:00,2015-03-31 23:59:59,0,{3},{4}", code, pwd, activity, card_id, card_code);
      }
    }
    excelReader.Close();
    f.Status = "处理完成";
  }
  writer.Flush();
  writer.Close();

  return true;

}
最终实现的软件的主界面如图所示

合并文件的操作画面如图所示

最后,个人觉得页面还是有点丑陋,可以增加一些动画,酷的样式什么的.但是这个不是我擅长的.

下载源代码

用wpf实现了多个excel文件的合并的更多相关文章

  1. 使用Aspose.Cell控件实现多个Excel文件的合并

    之前有写过多篇关于使用Apose.Cell控件制作自定义模板报表和通用的导出Excel表格数据的操作,对这个控件的功能还是比较满意,而且也比较便利.忽然有一天,一个朋友说:你已经有生成基于自定义模板报 ...

  2. python 作业 批量读取excel文件并合并为一张excel

    1 #!/usr/bin/env python 2 # coding: utf-8 3 4 def concat_file(a,b): 5 #如何批量读取并快速合并文件夹中的excel文件 6 imp ...

  3. excel-合并多个Excel文件--VBA合并当前目录下所有Excel工作簿中的所有工作表

    在网上找EXCEL多文件合并的方法,思路: 一.Linux 或者window+cmder,直接用命令行cat合并EXCEL文件,但是,需要安装辅助东西才能直接处理(也许也不可以,但是,可以用文件格式转 ...

  4. 多个excel文件内容合并到一个excel文件的多个sheet的小程序

    # -*- coding:utf-8 -*- import xlrd, xlsxwriter # 待合并excelallxls = ["D:\\excelcs\\***.xlsx" ...

  5. 导入导出Excel文件

    搭建环境 先新建web project ,然后Add Struts Capabilties: 下载导入导出Excel所需的jar包: poi-3.8-20120326.jar包  :  http:// ...

  6. 批处理快速合并多分Excel文件并将指定列的数据去重复

    1.批处理快速合并多个excel文件方法: 新建一个.txt文本文件,就命名为合并.txt吧. 而后开启文件,复制以下代码到文件中: @echo off E: cd xls dir copy *.cs ...

  7. EXCEL自动撤销合并单元格并填充相应内容(转帖)

    若EXCEL工作表有很多合并的单元格,要将所有合并的单元格撤销,并填充撤销合并前显示的内容,这是一项很繁琐且容易出错的工作.但可通过宏程序可轻松准确地搞定,方法如下: 一.实现该功能的Excel宏程序 ...

  8. C# WPF 进度条,根据读取数据显示进度条进度,根据Excel文件读取数据,进度条样式

    后台代码: //导入 private void Border_MouseLeftButtonUp_2(object sender, MouseButtonEventArgs e) { var path ...

  9. C# 7个读写Excel文件的类库

    转载自:http://www.cnblogs.com/wintersun/archive/2013/02/26/2933294.html 有时我们在项目需要操作Excel文件,读或写,导出数据等.   ...

随机推荐

  1. 保存网页MHT

    uses ADODB_TLB, CDO_TLB, ComObj,MSHTML;{$R *.dfm}{能把网页如 WWW.QQ.COM保存为一个单文件 .MHT但不能把一个 A.HTM 保存为一个单文件 ...

  2. 【ThinkingInC++】65、使用delete void*可能会出错

    /** * 书本:[ThinkingInC++] * 功能:使用delete void*可能会出错 * 时间:2014年10月5日14:31:43 * 作者:cutter_point */ #incl ...

  3. Javascript——初步

    1.基本概念 Javascript是一门脚本语言,它是一门解释性的语言.网页和用户之间实时.动态的进行交互. 2.特点 简单性:没有严格的数据类型.语句简单而紧凑. 安全性:仅仅能通过浏览器实现浏览和 ...

  4. android 双卡手机发短信/判断手机是否为双卡

    通过反射发现sendMultipartTextMessage多了一个phoneType的参数,这个参数就是这只用GMS还是CDMA卡发送的. phoneType获取方法,iTelephony.getA ...

  5. Python介绍、环境搭建(Eclipse插件)、第一个程序

    Python介绍 特点 优雅.明白.简单. 适合领域 1. Web站点和各种网络服务 2. 系统工具和脚本 3. 作为"胶水"语言把其它语言开发的模块包装起来方便使用 和其它语言对 ...

  6. 如何调试PHP的Core之获取基本信息 --------风雪之隅 PHP7核心开发者

    http://www.laruence.com/2011/06/23/2057.html https://github.com/laruence PHP开发组成员, Zend兼职顾问, PHP7核心开 ...

  7. 2016 11 9遇到问题 http请求的各种方式

    遇到问题:对接网易七鱼 调用他们接口是出现问题 1.对方要求  除上传文件外,其他所有接口请求Content-Type类型为:application/json;charset=utf-8:请求内容需要 ...

  8. Android 上使用 iconfont 的一种便捷方案

    最近在学习 AIOSO(Alibaba Internal Open Source Organization,即阿里巴巴内部开源组织) 的一个子项目MMCherryUI,这是一个流式布局,可以在运行时做 ...

  9. Amazon S3 上传文件 SSL23_GET_SERVER_HELLO握手错误

    题外话:今天偶尔来逛逛,发现我真是懒到家了.居然有半年前的留言我都没有来看过,真对不起留言的同学,希望他的问题已经解决了. 这两三天一直被亚马逊S3上传文件的问题困扰着,直到昨天晚上终于搞定了,工作群 ...

  10. PHP负载均衡

    待更新 版权声明:本文为博主原创文章,未经博主允许不得转载.