工具 : VS2015 + SQL Server 2008 R2
框架:三层+一般处理程序
方法:方法很多种,百度千奇百怪,总结下来更好更快的方法,以下会提到
最近接触到需要实现将一个excel表格的数据移植到数据库的需求,但此前从未接触过
百度+体会+探讨 总结下来以便后续需要使用,乐于分享给大家,望给予修正
少废话上代码
①数据库,移植到数据库肯定需要表吧,都懂不多说
②需要一个帮助类(当然自己写也可以,个人比较喜欢帮助类,即ExcelHelper类,放dal层)
一时半会可能看不懂(除了导入还有导出,挺全),c+v 懂?
另外注意,需要引用Nuget包 NOPI 使用nopi去导入导出我觉得目前自己掌握的来说最好
using System;
using System.Collections.Generic;
using System.Data;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;
using NPOI.HSSF.UserModel;
namespace Customer_DAL
{
public class NopiExcelHelper:IDisposable
{
private string fileName = null; //文件名
private IWorkbook workbook = null;
private FileStream fs = null;
private bool disposed;
public NopiExcelHelper(string fileName)
{
this.fileName = fileName;
disposed = false;
}
/// <summary>
/// 将DataTable数据导入到excel中
/// </summary>
/// <param name="data">要导入的数据</param>
/// <param name="isColumnWritten">DataTable的列名是否要导入</param>
/// <param name="sheetName">要导入的excel的sheet的名称</param>
/// <returns>导入数据行数(包含列名那一行)</returns>
public int DataTableToExcel(DataTable data, string sheetName, bool isColumnWritten)
{
int i = 0;
int j = 0;
int count = 0;
ISheet sheet = null;
fs = new FileStream(fileName, FileMode.OpenOrCreate, FileAccess.ReadWrite);
if (fileName.IndexOf(".xlsx") > 0) // 2007版本
workbook = new XSSFWorkbook();
else if (fileName.IndexOf(".xls") > 0) // 2003版本
workbook = new HSSFWorkbook();
try
{
if (workbook != null)
{
sheet = workbook.CreateSheet(sheetName);
}
else
{
return -1;
}
if (isColumnWritten == true) //写入DataTable的列名
{
IRow row = sheet.CreateRow(0);
for (j = 0; j < data.Columns.Count; ++j)
{
row.CreateCell(j).SetCellValue(data.Columns[j].ColumnName);
}
count = 1;
}
else
{
count = 0;