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 ...
随机推荐
- AP(affinity propagation)研究
待补充…… AP算法,即Affinity propagation,是Brendan J. Frey* 和Delbert Dueck于2007年在science上提出的一种算法(文章链接,维基百科) 现 ...
- windows7安装GitBash和GitGui
安装很简单,搜索安装就行. 配置: 1.$ ssh-keygen -t rsa -C "your_email@youremail.com" 将"your_email@yo ...
- [Linux] Linux指令汇总(持续更新中...)
写在前面: 以前真心没有玩过Linux系统,总感觉整天摆弄Linux的同学都是大牛.如今,在公司里实习需要远程登录Linux服务器,所有的代码都要在开发板上完成,所以被逼无奈也不得不定下心来好好学学L ...
- Fold Change和t分布
基因表达谱数据 基因表达谱可以用一个矩阵来表示,每一行代表一个基因,每一列代表一个样本(如图1).所有基因的表达谱数据在“gene_exp.txt”文件中存储,第一列为基因的entrez geneid ...
- windows环境下面安装Apache2.4+MySql5.7+PHP5.6
之前学习PHP一致是只用phpStudy集成开发环境,这对于新手而言无疑是帮助极大的,因为傻瓜式安装与使用方法减少了我们很多不必要的麻烦.但是作为一名合格的PHP开发人员,掌握PHP+MySQL+Ap ...
- Go - 项目收藏
谷歌官方维护了一个基于go语言的开源项目列表: https://github.com/golang/go/wiki/Projects Web框架 web.go.beego Go项目 httpmq:A ...
- C++中使用初始化列表的情况
http://blog.csdn.net/iceshirley/article/details/5688696 要理解这个问题,从概念上,我们要知道一点,那就是构造函数的执行过程会分成两个阶段:隐式或 ...
- [译]Android调整图像大小的一些方法
翻译自 某大神在Stack Overflow里的自问自答 (一般我们将Bitmap翻译为位图,但为了更好理解,在本文中我将它翻译成图像): 我们在开发的时候,经常需要从服务器中加载图像到客户端中,但有 ...
- PHP PDO的FETCH_NUM、FETCH_BOTH、FETCH_ASSOC
不容易混淆的有:FETCH_CLASS,FETCH_COLUMN,FETCH_OBJ... 数据库的连接准备部分 $dsn = 'mysql:host=127.0.0.1;port=3306;dbna ...
- Ruby基本类型
#!/usr/bin/ruby =begin Ruby支持的有5种类型的变量 全局变量:以$开头 未初始化的全局变量的值为0 并使用-w选项产生警告 全局变量的赋值会改变全局状态 不推荐使用全局变量 ...