用wpf实现了多个excel文件的合并

最近公司做了一个微信红包的项目,其中一个主要的工作内容是 将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;

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

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

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

下载源代码

时间: 2024-08-01 18:40:44

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

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

之前有写过多篇关于使用Apose.Cell控件制作自定义模板报表和通用的导出Excel表格数据的操作,对这个控件的功能还是比较满意,而且也比较便利.忽然有一天,一个朋友说:你已经有生成基于自定义模板报表了,可是我每个单位都导出一张相同的报表的话,我岂不是要生成很多文件,而且对比查看也不方便,有没有更好的办法合并他们到一个文件里面呢?这样我看报表就方便很多了.本文主要介绍如何实现基于一个自定义报表模式,生成多个类似报表合并在一个文件中具体操作. 查询Apose.Cell控件的使用介绍,WorkBo

python批量快速合并excel文件

简介 如果有很多excel文件需要合并到一个Excel文件中,使用复制粘贴来操作是非常痛苦,这时可以使用Python来批量自动操作. 把需要合并的Excel文件放到同一文件夹下. 安装需要的库 python环境Python3 pip3 install xlrd pip3 install xlsxwriter 代码 #!/usr/bin/env python # -*- coding: utf-8 -*- # @Author: Aiker Zhao # @Date : 2019/5/4 9:34

C#项目中操作Excel文件——使用NPOI库

转载自:http://blog.csdn.net/dcrmg/article/details/52356236# 感谢-牧野- 实际C#项目中经常会涉及到需要对本地Excel文件进行操作,特别是一些包含数据记录.分析.汇总功能模块的项目.常用的操作Excel文件的方法主要有三个: 1. OleDb: 这种方式是把整个Excel文件当做一个数据源来进行数据的读取操作. 优点:实现方式简单,读取速度快: 缺点:读取Excel数据的过程不太灵活,对内存的占用比较高,当数据量变的很大时,容易由于内存空间

.NET编程实现采用COM组件导出Excel文件实例

将.NET数据导出为Excel文件,有许多种方法,我这里介绍采用COM组件来操作Excel文件,并且还会涉及异步.同步.进程管理.文件定位等内容,使用WPF做到一个尽量可用的导出界面. 一.WPF前台 这个就不用多说了,堆上几个按钮,做一个数据录入的东西,一个状态条: 我这里的数据录入,就是用了几个Textbox,实际上大家可以用任何东西(DataGrid.ListView等),因为在最后都会转成List<MyData>的形式进行导出的,MyData是表示数据记录的对象: 1 // 自定义数据

ADF Faces导出Excel文件【附样例工程】

本文提供一个基于ADF Face组件开发样例工程,工程的实现过程分为3个部分以应对Excel导出开发中常见的处理. 1.空模版文件下载:将Excel文件视为普通文件提供下载操作. 2.数据文件输出,将数据内容输出为Excel文件,目标文件尽在服务端内存中存在,这种方式需要对Excel文件的内容处理,需要引入响应的类库. 3.模版文件填充数据后下载,基于服务端的物理文件为模板,将业务数据填入约定位置后提供下载,在实现方面需要为工作簿对象指定源文件输入流,并完成后续内容处理. 实现的基本思路,由AD

JExcel入门,JAVA读写Excel文件

(本人下的是jexcelapi_2_6_12.tar.gz,解压后将里面的jxl.jar复制到WEB-INF/lib目录下面即可) Java Excel API的jar包可以通过以下URL获得:(推荐) http://sourceforge.net/projects/jexcelapi/files/jexcelapi/2.6.6/jexcelapi_2_6_6.zip/download (包括所有版本):http://sourceforge.net/projects/jexcelapi/file

vs创建控制台程序使用C++读写excel文件(ODBC方式)

1.创建一个vs项目,选择windows控制台应用程序,项目名称输入cppRWexcel 2.在StdAfx.h文件最下方加入如下代码: #include <iostream> #include <afxdb.h> #include <odbcinst.h> using namespace std; 3.在cppRWexcel.cpp中写入如下代码: // cppRWexcel.cpp: 定义控制台应用程序的入口点. // #include "stdafx.h

eclipse中导入jdk源码、SpringMVC注解@RequestParam、SpringMVC文件上传源码解析、ajax上传excel文件

eclipse中导入jdk源码:http://blog.csdn.net/evolly/article/details/18403321, http://www.codingwhy.com/view/799.html. ------------------------------- SpringMVC注解@RequestParam:http://825635381.iteye.com/blog/2196911. --------------------------- SpringMVC文件上传源

Java通过jxl解析Excel文件入库,及日期格式处理方式 (附源代码)

JAVA可以利用jxl简单快速的读取文件的内容,但是由于版本限制,只能读取97-03  xls格式的Excel. 本文是项目中用到的一个实例,先通过上传xls文件(包含日期),再通过jxl进行读取上传的xls文件(文件格式见下user.xls),解析不为空的行与列,写入数据库. 文件user.xls格式为: 下面来看代码实例演示: 一.前端jsp页面(本来内容很多,这里精简了) <%@ page language="java" contentType="text/htm