C#读取Excel到DataTable的方法示例
作者:周继元的博客 发布时间:2023-04-28 07:04:32
标签:C#,Excel,DataTable
前提
在Windows下进行数据处理的时候最常见的情况莫过于读取Microsoft的Excel文件了,Excel的普及率惊人,是事实上的标准。以前的开发中我采用调用第三方类库 NPOI 的方式来处理Excel。这个方式有两个缺点:
需要依赖第三方类库NPOI
NPOI支持几乎全功能的Office条件,缺点就是复杂度也高。
如果只是简单的导入数据,完全可以有更加简单的方案,方案的限制条件为;
只支持Windows平台
只读取Excel文件
支持xls和xlsx文件格式
依赖
还是有依赖的 2007 Office System Driver: Data Connectivity Components
如果没有安装Driver,你会得到以下的报错:
Microsoft.ACE.OLEDB.12.0' provider is not registered on the local machine
代码
public static DataTable ReadAsTable(string xlsxFile, string sheetName = "Sheet1")
{
var connectionString = string.Format("Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties=\"Excel 12.0;HDR=Yes;IMEX=1\"", xlsxFile);
var adapter = new OleDbDataAdapter($"SELECT * FROM [{sheetName}$]", connectionString);
var ds = new DataSet();
adapter.Fill(ds, sheetName);
return ds.Tables[sheetName];
}
在 connectionString 中有两个Extended Properties可以根据需要进行修改:
HDR,这个属性表示Excel的第一行是不是转换成DataTable的列名(Column Name)还是普通数据处理。
IMEX,这个数据表明是不是读取类型,还是全部当做文本来读取,为了安全读取最好设置为1,即当做文本来处理: Treat data as text 。
技巧
有时候我们需要将读取的数据绑定到特定类型上,我们可以这样做:
var query = dt
.AsEnumerable()
.Where(x => x.Field<string>("phoneNumber") != string.Empty)
.Select(x => new Contact
{
FirstName= x.Field<string>("First Name"),
LastName = x.Field<string>("Last Name"),
PhoneNumber =x.Field<string>("Phone Number"),
});
来源:https://www.imzjy.com/blog/2018-08-08-read-excel-file-into-datatable
0
投稿
猜你喜欢
- 前言缓存主要是为了提高数据的读取速度。因为服务器和应用客户端之间存在着流量的瓶颈,所以读取大容量数据时,使用缓存来直接为客户端服务,可以减少
- 一、前言1、热更新代码的场景(1)当线上服务器出现问题时,有些时候现有的手段不足以发现问题所在,可能需要追加打印日志或者增加一些调试代码,如
- 关于注入数据说明1.不通过配置文件注入数据通过@Value将外部的值动态注入到Bean中,使用的情况有:注入普通字符串注入操作系统属性注入表
- 一、准备官网下载IntelliJ IDEA 2017 并安装好下载汉化包 (链接: https://pan.baidu.com/s/1JkU
- 一、简介   Seata 是一款开源的分布式事务解决方案,致力于在微服务架构下提供高性能和简单易用的分布
- Spring Boot 解决富文本上传图片跨域在前后端分离的情况下,后台所写的接口在前端调用的时候,可能前端浏览器已经读取到了数据,但是在前
- idea默认带的equals和hashcode引起的bug最近因规范需要,统一使用idea,使用的版本为2017.4.建立一个实体类,在添加
- 什么是ByteBuddyByteBuddy是一个java的运行时代码生成库,他可以帮助你以字节码的方式动态修改java类的代码。为什么需要B
- 本文帮助大家掌握Java多线程基础知识来对应日后碰到的问题,具体内容如下一、Java多线程面试问题1. 进程和线程之间有什么不同?一个进程是
- 异常分类可查的异常(checked exceptions):Exception下除了RuntimeException外的异常不可查的异常(u
- 摘要:Java8通过Function获取字段名,解决硬编码,效果类似于mybatis-plus的LambdaQueryWrapper。本文总
- 现在Java的大部分项目都是基于Maven, 在Maven项目中使用Selenium2. 非常简单。 首先你需要配置好
- 用户在注册网站信息的时候基本上都要数据验证码验证。那么图片验证码功能该如何实现呢?大概步骤是:1.在内存中创建缓存图片2.设置背景色3.画边
- 本文实例为大家分享了Flutter自定义圆盘取色器的具体代码,供大家参考,具体内容如下下面展示一些 内联代码片。圆盘取色器效果图完整代码im
- 前言:线性表(linear list)是n个具有相同特性的数据元素的有限序列。线性表是一种在实际中广泛使用的数据结构,常见的线性表:顺序表、
- 1.Overview经常研究.NET源码库的小伙伴会经常看到一个关键字volatile,那它在开发当中的作用是什么呢?我们一起来看看官方文档
- <profiles> <profile> <
- 定义: SharedPreferences
- 下面给大家介绍几种比较常见的解决办法,具体内容如下:1.有时候eclipse不自动编译,把project clean一下,让R.java重新
- 前言SPI 全称为 Service Provider Interface,是一种服务发现机制。SPI 的本质是将接口实现类的全限定名配置在文