C#导入导出数据你该知道的方法。
导入数据
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#导入导出数据你该知道的方法。的更多相关文章
- CRL快速开发框架系列教程九(导入/导出数据)
本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...
- mysql导入导出数据中文乱码解决方法小结
linux系统中 linux默认的是utf8编码,而windows是gbk编码,所以会出现上面的乱码问题. 解决mysql导入导出数据乱码问题 首先要做的是要确定你导出数据的编码格式,使用mysqld ...
- Android开发笔记:SQLite导入导出数据
SQLite是Android中最方便使用的数据库了,现在看下如何快速的在SQLite中导入导出数据. 首先由于是.NET项目转Android,原有数据库使用的是SQLSERVER,由于项目相同部分结构 ...
- 解决mysql导入导出数据乱码问题
最近在linux上面用mysqldump导出数据,放在windows系统中导入就会出现中文乱码,然后就会导致出现: Unknown MySQL server host和Can't connect to ...
- [转]mysql导入导出数据中文乱码解决方法小结
本文章总结了mysql导入导出数据中文乱码解决方法,出现中文乱码一般情况是导入导入时编码的设置问题,我们只要把编码调整一致即可解决此方法,下面是搜索到的一些方法总结,方便需要的朋友. linux系统中 ...
- oracle中导入导出数据备份数据库
原文:oracle中导入导出数据备份数据库 数据库所在位置 将数据导出到的文件名 用户名 备份数据库 :exp c ...
- PLSQL导入/导出数据方法
PLSQL导入/导出数据方法 PLSQL导入/导出数据方法 以前导数据库信息的时候,总是会先开启sql窗口,把自己手写的建表文件复制进去,然后再导入数据信息. 今天突然懒得去找以前的建表文件,而想用S ...
- oracle10g和oracle11g导入导出数据区别
其中flxuser为用户名,flxuser为密码,file值为导入到数据库中的备份文件. oracle10g和oracle11g导入导出数据的命令方式大有不同: oracle10g导入数据: imp ...
- 利用sqoop将hive数据导入导出数据到mysql
一.导入导出数据库常用命令语句 1)列出mysql数据库中的所有数据库命令 # sqoop list-databases --connect jdbc:mysql://localhost:3306 ...
随机推荐
- mysql 存储过程在批处理数据中的应用
最近批处理数据的时候,突然想到:为什么不使用存储过程进行数据批处理? 为什么要进行批处理? 自答:减少数据库连接次数,提高效率. 存储过程批处理数据的优点:一次编译,永久执行. 这次的批处理逻辑较简单 ...
- HTTP请求报文格式
HTTP报文是面向文本的,报文中的每一个字段都是一些ASCII码串,各个字段的长度是不确定的.HTTP有两类报文:请求报文和响应报文. 请求报文 一个HTTP请求报文由请求行(request line ...
- 【总结】/etc/rc.d/rc.local 与 /etc/profile .bash_profile .bashrc 文件执行顺序
登陆shell与交互式非登陆shell的区别 登录shell 所谓登录shell,指的是当用户登录系统时所取的那个 shell.登录shell属于交互式shell. 登录shell将查找4个不同的启动 ...
- Asp.Net Core--自定义基于策略的授权
翻译如下: 在封面下,角色授权和声明授权使用需求,需求的处理程序和预配置的策略. 这些构建块允许您在代码中表示授权评估,从而允许更丰富,可重用和容易测试的授权结构. 授权策略由一个或多个需求组成,并在 ...
- js中apply()和call()方法的使用
1.apply()方法 apply方法能劫持另外一个对象的方法,继承另外一个对象的属性. Function.apply(obj,args)方法能接收两个参数 obj:这个对象将代替Funct ...
- Microsoft.AspNet.SignalR 2.2
Nuget :http://www.nuget.org/packages/Microsoft.AspNet.SignalR/ What is SignalR? ASP.NET SignalR is a ...
- html5 Worker学习
HTML: <!DOCTYPE HTML> <html> <head> <meta charset="utf-8" /> <t ...
- Angular2 架构
1. 说明 Angular 2 是一个用 HTML 和 JavaScript (或者可以编译成JavaScript)来构建应用程序的框架.该框架包含了一系列的库. 在 Angular 里,我们这样 ...
- .NET LINQ 相等运算
相等运算 如果两个序列的对应元素相等且这两个序列具有相同数量的元素,则视这两个序列相等. 方法 方法名 说明 C# 查询表达式语法 Visual Basic 查询表达式语法 更多信息 Seq ...
- 如何在WIN2008或WIN2012 64位系统安装32位SQL2000
如何在WIN2008或WIN2012 64位系统安装32位SQL2000 在日常服务器,云服务器或VPS中,因尔特网络工程师遇到部分使用了WIN2008 或WN2012 64位系统的用户需要安装SQL ...