C# 导入Excel数据浅析
connygpt 2024-12-15 11:39 12 浏览
C# 导入 Excel 数据有多种方法。以下是几种常见的方法:
- 使用 OLEDB 连接器和 DataAdapter:使用 System.Data.OleDb 命名空间中的类,可以通过 OLEDB 连接器连接到 Excel 文件,然后使用 DataAdapter 填充 DataSet 或 DataTable。这种方法适用于较早的 Excel 格式(.xls)。
- 使用第三方库:你可以使用一些流行的第三方库,如EPPlus、NPOI、ClosedXML等来处理Excel文件。这些库提供了更多的功能和灵活性,可以更轻松地读取和写入Excel数据。
- 将Excel文件转换为CSV:你可以将Excel文件另存为CSV格式,然后使用C#中的文本处理功能来读取CSV文件。这种方法简单直接,不需要任何额外的库或组件。
这些方法各有优缺点,可以根据实际需求和项目要求选择适合的方法来导入 Excel 数据。
下面是这三种方法的简单示例:
- 使用 OLEDB
using System;
using System.Data;
using System.Data.OleDb;
class Program
{
static void Main()
{
// Excel文件路径
string excelFilePath = "路径/文件名.xlsx";
// 连接字符串
string connectionString = string.Format("Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties='Excel 12.0 Xml;HDR=YES;'", excelFilePath);
// 创建连接对象
using (OleDbConnection connection = new OleDbConnection(connectionString))
{
// 打开连接
connection.Open();
// 查询语句
string query = "SELECT * FROM [Sheet1$]"; // Sheet1是Excel中的工作表名称
// 创建DataAdapter对象
using (OleDbDataAdapter adapter = new OleDbDataAdapter(query, connection))
{
// 创建DataTable对象
DataTable dataTable = new DataTable();
// 使用DataAdapter填充DataTable
adapter.Fill(dataTable);
// 遍历DataTable中的数据
foreach (DataRow row in dataTable.Rows)
{
// 获取每一行的数据
string column1Value = row["列名1"].ToString(); // 列名1是Excel中的列名
string column2Value = row["列名2"].ToString(); // 列名2是Excel中的列名
// 在此处可以对数据进行处理或存储到其他地方
Console.WriteLine("列1值: " + column1Value);
Console.WriteLine("列2值: " + column2Value);
}
}
}
}
}
以上代码使用了OleDb连接器来连接Excel文件,并使用DataAdapter来填充DataTable。然后,可以遍历DataTable中的数据,并对其进行处理或存储到其他地方。请注意,上述代码中的路径/文件名.xlsx应替换为实际的Excel文件路径和文件名。另外,Sheet1和列名1、列名2应替换为实际的工作表名称和列名。
- 使用第三方库(NPOI)
using System;
using System.Data;
using System.IO;
using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;
class Program
{
static void Main()
{
// Excel文件路径
string excelFilePath = "路径/文件名.xlsx";
// 创建工作簿对象
using (FileStream file = new FileStream(excelFilePath, FileMode.Open, FileAccess.Read))
{
IWorkbook workbook = new XSSFWorkbook(file);
// 获取第一个工作表
ISheet sheet = workbook.GetSheetAt(0);
// 获取行数和列数
int rowCount = sheet.LastRowNum + 1;
int columnCount = sheet.GetRow(0).LastCellNum;
// 创建DataTable对象
DataTable dataTable = new DataTable();
// 添加列名
for (int i = 0; i < columnCount; i++)
{
ICell cell = sheet.GetRow(0).GetCell(i);
dataTable.Columns.Add(cell.ToString());
}
// 添加数据行
for (int i = 1; i < rowCount; i++)
{
DataRow dataRow = dataTable.NewRow();
for (int j = 0; j < columnCount; j++)
{
ICell cell = sheet.GetRow(i).GetCell(j);
dataRow[j] = cell.ToString();
}
dataTable.Rows.Add(dataRow);
}
// 遍历DataTable中的数据
foreach (DataRow row in dataTable.Rows)
{
// 获取每一行的数据
string column1Value = row["列名1"].ToString(); // 列名1是Excel中的列名
string column2Value = row["列名2"].ToString(); // 列名2是Excel中的列名
// 在此处可以对数据进行处理或存储到其他地方
Console.WriteLine("列1值: " + column1Value);
Console.WriteLine("列2值: " + column2Value);
}
}
}
}
在上述代码中,我们使用NPOI库中的XSSFWorkbook和ISheet对象来读取Excel文件的内容。我们遍历每一行并获取每一列的数据,并将其存储在DataTable中。请注意,上述代码中的路径/文件名.xlsx应替换为实际的Excel文件路径和文件名。另外,列名1、列名2应替换为实际的Excel列名。
3.将Excel文件转换为CSV
using System;
using System.Data;
using System.IO;
using ExcelDataReader;
class Program
{
static void Main()
{
// Excel文件路径
string excelFilePath = "路径/文件名.xlsx";
// CSV文件路径
string csvFilePath = "路径/文件名.csv";
// 读取Excel文件
using (var stream = File.Open(excelFilePath, FileMode.Open, FileAccess.Read))
{
using (var reader = ExcelReaderFactory.CreateReader(stream))
{
// 创建CSV文件
using (var csvWriter = new StreamWriter(csvFilePath))
{
// 遍历每个工作表
do
{
while (reader.Read())
{
// 写入CSV文件
for (int i = 0; i < reader.FieldCount; i++)
{
csvWriter.Write(reader.GetValue(i));
csvWriter.Write(",");
}
csvWriter.WriteLine();
}
} while (reader.NextResult());
}
}
}
// 读取CSV文件并导入数据
using (StreamReader csvReader = new StreamReader(csvFilePath))
{
string line;
while ((line = csvReader.ReadLine()) != null)
{
string[] values = line.Split(',');
// 处理CSV数据
foreach (string value in values)
{
// 在此处可以对数据进行处理或存储到其他地方
Console.WriteLine("值: " + value);
}
}
}
}
}
上述代码使用了ExcelDataReader库来读取Excel文件的内容,并使用StreamWriter来创建和写入CSV文件。然后,我们再次读取CSV文件并导入数据,进行进一步的处理或存储。请注意,上述代码中的路径/文件名.xlsx和路径/文件名.csv应替换为实际的Excel文件路径和文件名,以及目标CSV文件的路径和文件名。
这些方法各有优缺点,可以根据实际需求和项目要求选择适合的方法来导入 Excel 数据。
创作不易,如果您喜欢还请帮忙点赞关注,谢谢![作揖]
相关推荐
- 3分钟让你的项目支持AI问答模块,完全开源!
-
hello,大家好,我是徐小夕。之前和大家分享了很多可视化,零代码和前端工程化的最佳实践,今天继续分享一下最近开源的Next-Admin的最新更新。最近对这个项目做了一些优化,并集成了大家比较关注...
- 干货|程序员的副业挂,12个平台分享
-
1、D2adminD2Admin是一个完全开源免费的企业中后台产品前端集成方案,使用最新的前端技术栈,小于60kb的本地首屏js加载,已经做好大部分项目前期准备工作,并且带有大量示例代码,助...
- Github标星超200K,这10个可视化面板你知道几个
-
在Github上有很多开源免费的后台控制面板可以选择,但是哪些才是最好、最受欢迎的可视化控制面板呢?今天就和大家推荐Github上10个好看又流行的可视化面板:1.AdminLTEAdminLTE是...
- 开箱即用的炫酷中后台前端开源框架第二篇
-
#头条创作挑战赛#1、SoybeanAdmin(1)介绍:SoybeanAdmin是一个基于Vue3、Vite3、TypeScript、NaiveUI、Pinia和UnoCSS的清新优...
- 搭建React+AntDeign的开发环境和框架
-
搭建React+AntDeign的开发环境和框架随着前端技术的不断发展,React和AntDesign已经成为越来越多Web应用程序的首选开发框架。React是一个用于构建用户界面的JavaScrip...
- 基于.NET 5实现的开源通用权限管理平台
-
??大家好,我是为广大程序员兄弟操碎了心的小编,每天推荐一个小工具/源码,装满你的收藏夹,每天分享一个小技巧,让你轻松节省开发效率,实现不加班不熬夜不掉头发,是我的目标!??今天小编推荐一款基于.NE...
- StreamPark - 大数据流计算引擎
-
使用Docker完成StreamPark的部署??1.基于h2和docker-compose进行StreamPark部署wgethttps://raw.githubusercontent.com/a...
- 教你使用UmiJS框架开发React
-
1、什么是Umi.js?umi,中文可发音为乌米,是一个可插拔的企业级react应用框架。你可以将它简单地理解为一个专注性能的类next.js前端框架,并通过约定、自动生成和解析代码等方式来辅助...
- 简单在线流程图工具在用例设计中的运用
-
敏捷模式下,测试团队的用例逐渐简化以适应快速的发版节奏,大家很早就开始运用思维导图工具比如xmind来编写测试方法、测试点。如今不少已经不少利用开源的思维导图组件(如百度脑图...)来构建测试测试...
- 【开源分享】神奇的大数据实时平台框架,让Flink&Spark开发更简单
-
这是一个神奇的框架,让Flink|Spark开发更简单,一站式大数据实时平台!他就是StreamX!什么是StreamX大数据技术如今发展的如火如荼,已经呈现百花齐放欣欣向荣的景象,实时处理流域...
- 聊聊规则引擎的调研及实现全过程
-
摘要本期主要以规则引擎业务实现为例,陈述在陌生业务前如何进行业务深入、调研、技术选型、设计及实现全过程分析,如果你对规则引擎不感冒、也可以从中了解一些抽象实现过程。诉求从硬件采集到的数据提供的形式多种...
- 【开源推荐】Diboot 2.0.5 发布,自动化开发助理
-
一、前言Diboot2.0.5版本已于近日发布,在此次发布中,我们新增了file-starter组件,完善了iam-starter组件,对core核心进行了相关优化,让devtools也支持对IAM...
- 微软推出Copilot Actions,使用人工智能自动执行重复性任务
-
IT之家11月19日消息,微软在今天举办的Ignite大会上宣布了一系列新功能,旨在进一步提升Microsoft365Copilot的智能化水平。其中最引人注目的是Copilot...
- Electron 使用Selenium和WebDriver
-
本节我们来学习如何在Electron下使用Selenium和WebDriver。SeleniumSelenium是ThoughtWorks提供的一个强大的基于浏览器的开源自动化测试工具...
- Quick 'n Easy Web Builder 11.1.0设计和构建功能齐全的网页的工具
-
一个实用而有效的应用程序,能够让您轻松构建、创建和设计个人的HTML网站。Quick'nEasyWebBuilder是一款全面且轻巧的软件,为用户提供了一种简单的方式来创建、编辑...
- 一周热门
- 最近发表
- 标签列表
-
- kubectlsetimage (56)
- mysqlinsertoverwrite (53)
- addcolumn (54)
- helmpackage (54)
- varchar最长多少 (61)
- 类型断言 (53)
- protoc安装 (56)
- jdk20安装教程 (60)
- rpm2cpio (52)
- 控制台打印 (63)
- 401unauthorized (51)
- vuexstore (68)
- druiddatasource (60)
- 企业微信开发文档 (51)
- rendertexture (51)
- speedphp (52)
- gitcommit-am (68)
- bashecho (64)
- str_to_date函数 (58)
- yum下载包及依赖到本地 (72)
- jstree中文api文档 (59)
- mvnw文件 (58)
- rancher安装 (63)
- nginx开机自启 (53)
- .netcore教程 (53)