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 ...
随机推荐
- Unity3D 之脚本架构,优雅地管理你的代码
本文参考雨松MOMO大神的帖子: 图片全部来自他的帖子(请允许我偷懒下) --------------------------------------------------------------- ...
- MySQL提示:The server quit without updating PID file问题的解决办法(转载)
MySQL提示:The server quit without updating PID file问题的解决办法 今天网站web页面提交内容到数据库,发现出错了,一直提交不了,数找了下原因,发现数据写 ...
- tyvj1034 尼克的任务
描述 尼克每天上班之前都连接上英特网,接收他的上司发来的邮件,这些邮件包含了尼克主管的部门当天要完成的全部任务,每个任务由一个开始时刻与一个持续时间构成.尼克的一个工作日为N分钟,从第一分钟开始到第N ...
- [Machine Learning] 机器学习常见算法分类汇总
声明:本篇博文根据http://www.ctocio.com/hotnews/15919.html整理,原作者张萌,尊重原创. 机器学习无疑是当前数据分析领域的一个热点内容.很多人在平时的工作中都或多 ...
- Go - 数组 和 切片(array、slice)
一.数组 与其他大多数语言类似,Go语言的数组也是一个元素类型相同的定长的序列. (1)数组的创建 数组有 3 种创建方式: 1) [length]Type 2) [length]Type{value ...
- Hydra用户手册
Hydra 参数: -R继续从上一次进度接着破解 -S大写,采用SSL链接 -s <PORT>小写,可通过这个参数指定非默认端口 -l <LOGIN>指定破解的用户,对特定用户 ...
- SharePreferences的DB实现
存储一些简单数据的时候,最快的实现是用SharePreferences,但SharePreferences的可靠性不高,在某些非官方ROM上,总是存取失败.后来想到用数据库来存取.产品中,存取的数据项 ...
- c# 不同窗体之间传值和调用
1.子窗体事件刷新父窗体界面值 子窗体定义委托和事件 //声明一个委托 public delegate void DisplayUpdateDelegate(string str); //声明事件 p ...
- .NET 清理非托管资源
Dispose 类型的 Dispose 方法应释放它拥有的所有资源.它还应该通过调用其父类型的 Dispose 方法释放其基类型拥有的所有资源.该父类型的 Dispose 方法应该释放它拥有的所有资源 ...
- <%#Eval if判断用法
1.绑定Repeater 基础用法 <%#Eval("RoleID")%> 2.简单判断用法 <td> <%# Convert.ToBoolean(E ...