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


猜你喜欢
- 简介石头剪刀布游戏,进入游戏后,玩家需要输入玩家姓名。系统界面之后弹出欢迎界面,玩家可以选择出拳或者退出游戏。玩家选择出拳后同电脑出拳比较,
- 首先选择保存图片的路径:saveFileDialog1.Title = "保存"; &
- 本文实例为大家分享了java实现人员信息管理系统的具体代码,供大家参考,具体内容如下实现增删改查.java入门的练手小程序1.Person类
- 在C#中,当引用类型需要转换的时候,经常会用到关键字is、as以及显式强转。本篇来体验这三者的用法。先来梳理.NET引用类型转换的"
- 表:需求:将表中的数据,按照一级二级分类返回给前端json数据代码实现:java代码: public class ResultIndustr
- MainActivity如下: package cn.testcallback; import android.os.Bundle; imp
- 一家移动互联网公司,说到底,要盈利总是需要付费用户的,自己开发支付系统对于资源有限的公司来说显然不太明智,国内已经有多家成熟的移动支付提供商
- 什么是响应式简单来说当数据发生变化时,对数据有依赖的代码会重新执行。例如在Vue中,当我们的数据发生改变,界面上对该数据的引用组件会重新渲染
- 1. 可空类型修饰符(?):引用类型可以使用空引用表示一个不存在的值,而值类型通常不能表示为空。例如:
- 时间轴主要使用Recyclerview来实现。开发语言使用Kotlin,代码相对java少了许多也简洁许多源代码下载地址效果图:MainAc
- 本文实例为大家分享了Android百度地图之方向感应和模式更改,供大家参考,具体内容如下目标效果:菜单中设置几种模式,点击可查看不同的地图形
- 哈喽大家好啊,我是Hydra。Spring作为项目中不可缺少的底层框架,提供的最基础的功能就是bean的管理了。bean的注入相信大家都比较
- 使用java语言用集合存储数据实现学生信息管理系统,在控制台上编译执行可以实现基本的学生信息增加、删除、修改、查询功能IO版可以参考我的另外
- # 看题目是不是很绕,这个我也不知道怎么才能更简单的表达了# 先看代码:public class Common {public static
- 1,验证传入路径是否为正确的路径名(Windows系统,其他系统未使用)Java代码 // 验证字符串是否为正确路径名的正则表达式 
- SpringMVC AbstractAnnotationConfigDispatcherSerServlet3.0环境中,容器会在类路径中查
- 废话不多说了,直接给大家贴代码了,具体代码如下所述:package com.example.esp8266;import java.io.I
- 最近做项目中遇到ToolBar因为不同的界面toobar不同为了描述统一的风格。相信大家也非常清楚,大多数ToolBar包括以下几个方面左标
- 1 导入需要渐变的图片如果需要实现图片之间的渐变效果,我们需要两张照片,这样才能实现照片1到照片2的渐变。在路径 /res/values/
- 上一次自己写了一个多线程断点续传下载的demo,过于麻烦,bug超多,所以我学习使用xutils来完成此功能。先将xutils依赖搭建好(上