导入数据

using NPOI.HSSF.UserModel;
using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;
using System;
using System.Collections.Generic;
using System.Data;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace Common
{
public static class Import
{
/// <summary>
/// 获取导入的Excel的列名(第一行Titile)
/// </summary>
/// <returns></returns>
public static List<string> GetFieldNames(string filePath)
{
ISheet sheet = GetSheet(filePath);
List<string> filedNameList = new List<string>();
try
{
if (sheet != null)
{
IRow firstRow = sheet.GetRow();
int cellCount = firstRow.LastCellNum; //一行最后一个cell的编号 即总的列数 for (int i = firstRow.FirstCellNum; i < cellCount; ++i)
{
ICell cell = firstRow.GetCell(i);
if (cell != null)
{
string cellValue = cell.StringCellValue;
if (cellValue != null)
{
filedNameList.Add(cellValue);
}
}
}
} }
catch (Exception ex)
{
throw ex;
}
return filedNameList; }
/// <summary>
/// 将excel中的数据导入到DataTable中
/// </summary>
/// <param name="sheetName">excel工作薄sheet的名称</param>
/// <param name="isFirstRowColumn">第一行是否是DataTable的列名</param>
/// <returns>返回的DataTable</returns>
public static DataTable ExcelToDataTable(string filePath)
{
ISheet sheet = GetSheet(filePath);
DataTable data = new DataTable();
int startRow = ;
try
{
if (sheet != null)
{
IRow firstRow = sheet.GetRow();
int cellCount = firstRow.LastCellNum; //一行最后一个cell的编号 即总的列数 for (int i = firstRow.FirstCellNum; i < cellCount; ++i)
{
ICell cell = firstRow.GetCell(i);
if (cell != null)
{
string cellValue = cell.StringCellValue;
if (cellValue != null)
{
DataColumn column = new DataColumn(cellValue);
data.Columns.Add(column);
}
}
}
startRow = sheet.FirstRowNum + ; //最后一列的标号
int rowCount = sheet.LastRowNum;
for (int i = startRow; i <= rowCount; ++i)
{
IRow row = sheet.GetRow(i);
if (row == null) continue; //没有数据的行默认是null        DataRow dataRow = data.NewRow();
for (int j = row.FirstCellNum; j < cellCount; ++j)
{
if (row.GetCell(j) != null) //同理,没有数据的单元格都默认是null
dataRow[j] = row.GetCell(j).ToString();
}
data.Rows.Add(dataRow);
}
} return data;
}
catch (Exception ex)
{
throw ex;
}
} /// <summary>
/// 获取sheet
/// </summary>
/// <param name="filePath"></param>
/// <returns></returns>
private static ISheet GetSheet(string filePath)
{
ISheet sheet = null;
MemoryStream memoryStream = CommonHelper.ReadFile(filePath);
memoryStream.Position = ;
try
{
IWorkbook workbook = null;
if (filePath.IndexOf(".xlsx") > ) // 2007版本
{
workbook = new XSSFWorkbook(memoryStream);
}
else if (filePath.IndexOf(".xls") > ) // 2003版本
workbook = new HSSFWorkbook(memoryStream);
memoryStream.Close();
memoryStream.Dispose(); sheet = workbook.GetSheetAt();
return sheet;
}
catch (Exception ex)
{
memoryStream.Close();
memoryStream.Dispose();
throw ex;
}
}
}
}

导出数据

using CRM.Models.Base;
using NPOI.HSSF.UserModel;
using NPOI.SS.UserModel;
using System;
using System.Collections.Generic;
using System.Data;
using System.IO;
using System.Linq;
using System.Reflection;
using System.Text;
using System.Threading.Tasks; namespace Common.Utils
{
public class Export
{
public static byte[] ExportToExcel<T>(List<T> modelList)
{
byte[] resultByte = null; IWorkbook workbook = new HSSFWorkbook();//创建Workbook对象
ISheet sheet = workbook.CreateSheet(); //填充表头
IRow dataRow = sheet.CreateRow();
System.Reflection.PropertyInfo[] ps = typeof(T).GetProperties();
for (int i = ; i < ps.Count(); i++)
{
//object obj = ps[i].GetValue(typeof(T), null);
string name = ps[i].Name;
dataRow.CreateCell(i).SetCellValue(name);
} //填充内容
for (int i = ; i < modelList.Count; i++)
{
dataRow = sheet.CreateRow(i + );
var type = modelList[i].GetType();
ps = type.GetProperties();
for (int j = ; j < ps.Count(); j++)
{
object obj = ps[j].GetValue(modelList[i], null);
if (obj != null)
dataRow.CreateCell(j).SetCellValue(obj.ToString());
}
} //保存
using (MemoryStream ms = new MemoryStream())
{
workbook.Write(ms);
resultByte = ms.ToArray();
ms.Dispose();
} return resultByte;
} /// <summary>
/// 根据DateTable导出Excel
/// </summary>
/// <param name="dt"></param>
/// <returns></returns>
public static byte[] ExportToExcel(DataTable dt)
{
byte[] resultByte = null; IWorkbook workbook = new HSSFWorkbook();//创建Workbook对象
ISheet sheet = workbook.CreateSheet(); //填充表头
IRow dataRow = sheet.CreateRow(); for (int i = ; i < dt.Columns.Count; i++)
{
string name = dt.Columns[i].ColumnName;
dataRow.CreateCell(i).SetCellValue(name);
} //填充内容
for (int i = ; i < dt.Rows.Count; i++)
{ dataRow = sheet.CreateRow(i + );
for (int j = ; j < dt.Columns.Count; j++)
{
object obj = dt.Rows[i][j];
if (obj != null)
{
dataRow.CreateCell(j).SetCellValue(obj.ToString());
}
}
} //保存
using (MemoryStream ms = new MemoryStream())
{
workbook.Write(ms);
resultByte = ms.ToArray();
ms.Dispose();
} return resultByte;
}
}
}

C#导入导出数据你该知道的方法。的更多相关文章

  1. CRL快速开发框架系列教程九(导入/导出数据)

    本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...

  2. mysql导入导出数据中文乱码解决方法小结

    linux系统中 linux默认的是utf8编码,而windows是gbk编码,所以会出现上面的乱码问题. 解决mysql导入导出数据乱码问题 首先要做的是要确定你导出数据的编码格式,使用mysqld ...

  3. Android开发笔记:SQLite导入导出数据

    SQLite是Android中最方便使用的数据库了,现在看下如何快速的在SQLite中导入导出数据. 首先由于是.NET项目转Android,原有数据库使用的是SQLSERVER,由于项目相同部分结构 ...

  4. 解决mysql导入导出数据乱码问题

    最近在linux上面用mysqldump导出数据,放在windows系统中导入就会出现中文乱码,然后就会导致出现: Unknown MySQL server host和Can't connect to ...

  5. [转]mysql导入导出数据中文乱码解决方法小结

    本文章总结了mysql导入导出数据中文乱码解决方法,出现中文乱码一般情况是导入导入时编码的设置问题,我们只要把编码调整一致即可解决此方法,下面是搜索到的一些方法总结,方便需要的朋友. linux系统中 ...

  6. oracle中导入导出数据备份数据库

    原文:oracle中导入导出数据备份数据库 数据库所在位置                         将数据导出到的文件名                    用户名 备份数据库 :exp c ...

  7. PLSQL导入/导出数据方法

    PLSQL导入/导出数据方法 PLSQL导入/导出数据方法 以前导数据库信息的时候,总是会先开启sql窗口,把自己手写的建表文件复制进去,然后再导入数据信息. 今天突然懒得去找以前的建表文件,而想用S ...

  8. oracle10g和oracle11g导入导出数据区别

    其中flxuser为用户名,flxuser为密码,file值为导入到数据库中的备份文件. oracle10g和oracle11g导入导出数据的命令方式大有不同: oracle10g导入数据: imp  ...

  9. 利用sqoop将hive数据导入导出数据到mysql

    一.导入导出数据库常用命令语句 1)列出mysql数据库中的所有数据库命令  #  sqoop list-databases --connect jdbc:mysql://localhost:3306 ...

随机推荐

  1. [Linux] 账户管理命令(二)

    组管理 1)groupadd 用于添加一个用户组. 格式:groupadd [-g -o GID] GROUP 其中:  GROUP:是要添加的组名   -g:用于指定 GID,默认为使用当前最大的 ...

  2. PHP数据采集curl常用的5个例子

    用php ,curl主要是抓取数据,当然我们可以用其他的方法来抓取,比如fsockopen,file_get_contents等.但是只能抓那些能直接访问的页面,如果要抓取有页面访问控制的页面,或者是 ...

  3. PHP读写大“二进制”文件,不必申请很大内存(fopen、fread、fwrite、fclose)

    <?php /** * 读写大二进制文件,不必申请很大内存 * 只有读取到内容才创建文件 * 保证目录可写 * * @param string $srcPath 源文件路径 * @param s ...

  4. jquery.print.js 打印插件

    <script language="javascript" src="jquery-1.4.4.min.js"></script> &l ...

  5. PYTHON 写函数,计算传入字符串中【数字、字母、空格、以及其他的个数】

    def func1(s): al_num = 0 spance_num = 0 digit_num = 0 others_num = 0 for i in s: if i.isdigit(): # i ...

  6. python之路七

    静态方法 通过@staticmethod装饰器即可把其装饰的方法变为一个静态方法,什么是静态方法呢?其实不难理解,普通的方法,可以在实例化后直接调用,并且在方法里可以通过self.调用实例变量或类变量 ...

  7. selenium+testng+ant+jenkins 手记

    会不会搭建测试平台是一般测试工程师和高级测试工程师分水岭 ----tobecrazy 我们项目有现成的测试平台,使用的是selenium grid+testng+ant+jenkins+VM 但是我平 ...

  8. ACM/ICPC 之 卡卡的矩阵旅行-最小费用最大流(可做模板)(POJ3422)

    将每个点拆分成原点A与伪点B,A->B有两条单向路(邻接表实现时需要建立一条反向的空边,并保证环路费用和为0),一条残留容量为1,费用为本身的负值(便于计算最短路),另一条残留容量+∞,费用为0 ...

  9. Websocket通讯简析

    什么是Websocket Websocket是一种全新的协议,不属于HTTP无状态协议,协议名为"ws",这意味着一个Websocket连接地址会是这样的写法:ws://**.We ...

  10. .NET LINQ 数据分组

    数据分组      分组指将数据放入组中以便每个组中的元素共享公共特性的操作.   方法 方法名 说明 C# 查询表达式语法 Visual Basic 查询表达式语法 更多信息 GroupBy 对共享 ...