.NET用C#导入Excel数据到数据库
将Excel文件中的数据导入到数据库中不仅能够提升数据处理的效率和准确性,还能极大地促进数据分析和决策制定的过程。尤其在企业级应用中,Excel作为数据输入和初步整理的工具非常普遍,但其功能对于复杂查询、大规模数据管理和跨部门的数据共享来说有所局限。通过使用C#在.NET平台上实现这一过程,可以充分利用其强大的数据操作能力和丰富的库支持,确保数据从Excel无缝迁移到诸如SQLite等关系型数据库中,从而实现更高效的数据管理、增强的数据安全性和更好的性能优化,同时为后续的数据挖掘和商业智能分析打下坚实的基础。
本文将介绍如何在.NET平台使用C#导入Excel文件数据到数据库中。
文章目录
- 导入Excel数据到SQLite数据库
- 导入Excel数据到SQLite数据库
本文所使用的方法需要用到免费的Free Spire.XLS for .NET,NuGet:PM> Install-Package FreeSpire.XLS,以及System.Data.SQLite,NuGet:PM> Install-Package System.Data.SQLite。
导入Excel数据到SQLite数据库
我们可以使用Free Spire.XLS for .NET中的Workbook.LoadFromFile方法载入Excel文件,然后使用CellRange.Value读取单元格的数据,并搭配System.Data.SQLite模块将数据写入到SQLite数据库中。以下是操作步骤示例:
以下是将提供的C#代码转换为操作步骤的介绍:
- 设置SQLite数据库文件路径为
Sample.db,并指定Excel输出文件路径为output/DatabaseToExcel.xlsx。 - 创建一个新的
Workbook实例以表示Excel工作簿,并清除默认的工作表。 - 使用
SQLiteConnection创建一个到SQLite数据库的新连接,并打开这个连接。 - 通过调用
GetSchema("Tables")从数据库获取所有表的名字,并存储在一个DataTable对象中。 - 遍历每个表名:
- 对于每个表,添加一个新的工作表到工作簿中,工作表名称设为当前表名。
- 构建SQL查询语句以选择表中的所有数据,并使用
SQLiteCommand执行此查询。 - 使用
SQLiteDataReader读取查询结果,并进行以下操作:- 获取列名并将它们写入新工作表的第一行。
- 设置第一行(即标题行)的字体样式为粗体,字号为12。
- 继续遍历数据行,并对每一行执行以下操作:
- 将每一行的数据值写入相应的单元格中。
- 自动调整每列的宽度以适应内容。
- 设置数据行的字体大小为11。
- 关闭与SQLite数据库的连接。
- 保存生成的工作簿到之前定义的Excel文件路径,并释放
workbook对象使用的资源。
代码示例:
using System.Data.SQLite;
using Spire.Xls;namespace ExcelToSQLite
{class Program{static void Main(string[] args){// Excel 文件路径string excelFilePath = "G:/Documents/Sample37.xlsx";// SQLite 数据库路径string sqliteFilePath = "output/Database.db";// 打开 Excel 文件Workbook workbook = new Workbook();workbook.LoadFromFile(excelFilePath);// 如果数据库文件不存在,则创建它if (!File.Exists(sqliteFilePath)){SQLiteConnection.CreateFile(sqliteFilePath);Console.WriteLine("已创建新的 SQLite 数据库文件:output.db");}// 创建 SQLite 连接using (SQLiteConnection connection = new SQLiteConnection($"Data Source={sqliteFilePath};Version=3;")){connection.Open();// 遍历每个工作表foreach (Worksheet sheet in workbook.Worksheets){string tableName = sheet.Name;// 获取第一行作为列名var columns = sheet.Rows[0].CellList;string createTableQuery = $"CREATE TABLE IF NOT EXISTS [{tableName}] (";foreach (var column in columns){createTableQuery += $"[{column.Value}] TEXT,";}createTableQuery = createTableQuery.TrimEnd(',') + ");";// 创建表using (SQLiteCommand createTableCommand = new SQLiteCommand(createTableQuery, connection)){createTableCommand.ExecuteNonQuery();}// 插入数据for (int i = 1; i < sheet.Rows.Length; i++) // 跳过第一行{var row = sheet.Rows[i];string insertQuery = $"INSERT INTO [{tableName}] VALUES (";foreach (var cell in row.CellList){insertQuery += $"'{cell.Value?.Replace("'", "''")}',"; // 防止 SQL 注入}insertQuery = insertQuery.TrimEnd(',') + ");";using (SQLiteCommand insertCommand = new SQLiteCommand(insertQuery, connection)){insertCommand.ExecuteNonQuery();}}}connection.Close();workbook.Dispose();}Console.WriteLine("Excel 数据已成功写入新的 SQLite 数据库!");}}
}
结果

导入Excel数据到SQLite数据库
写入到Access数据库则需要用到System.Data.OleDb模块,以下是操作步骤示例:
以下是将提供的C#代码转换为操作步骤的介绍:
- 设置Excel文件路径为
Sample.xlsx,并指定Access数据库文件路径为output/Database.accdb。 - 使用
Workbook类打开指定路径的Excel文件,并加载该文件到内存中。 - 创建一个用于连接Access数据库的OleDb连接字符串。
- 检查Access数据库文件是否存在。如果不存在,则提示用户首先创建Access数据库文件,并终止程序执行。
- 创建一个新的OleDb连接对象,并打开与Access数据库的连接。
- 遍历Excel工作簿中的每个工作表:
- 获取当前工作表的名称,并将其作为新表的名称。
- 从工作表的第一行获取列名,并构建创建新表的SQL语句,假定所有列的数据类型均为文本类型(TEXT)。
- 尝试执行以下操作,对于每个工作表:
- 使用构建的
CREATE TABLESQL语句创建新的表。
- 使用构建的
- 对于每个工作表中的每一行数据(跳过第一行,因为它包含列名):
- 构建
INSERT INTOSQL语句以插入数据行,同时处理可能的SQL注入问题,例如通过转义单引号。
- 构建
- 执行构建的
INSERT INTO命令,将一行数据插入到对应的Access表中。 - 如果在处理某个工作表时发生错误,捕获异常并打印错误信息,继续处理下一个工作表。
- 关闭与Access数据库的连接,并释放
workbook对象使用的资源。
代码示例:
using System.Data.OleDb;
using Spire.Xls;namespace ExcelToAccess
{class Program{static void Main(string[] args){// Excel 文件路径string excelFilePath = "G:/Documents/Sample37.xlsx";// Access 数据库路径string accessDbPath = "output/Database.accdb";// 打开 Excel 文件Workbook workbook = new Workbook();workbook.LoadFromFile(excelFilePath);// 为 Access 创建 OleDb 连接字符串string connectionString = $"Provider=Microsoft.ACE.OLEDB.12.0;Data Source={accessDbPath};Persist Security Info=False;";// 如果数据库文件不存在,提示创建 - 注意:此步骤通常在代码外部完成if (!System.IO.File.Exists(accessDbPath)){Console.WriteLine("请先创建一个 Access 数据库文件。");return;}// 创建 OleDb 连接using (OleDbConnection connection = new OleDbConnection(connectionString)){connection.Open();// 遍历每个工作表foreach (Worksheet sheet in workbook.Worksheets){string tableName = sheet.Name;// 获取第一行作为列名var columns = sheet.Rows[0].CellList;string createTableQuery = $"CREATE TABLE [{tableName}] (";foreach (var column in columns){createTableQuery += $"[{column.Value}] TEXT,"; // 假设所有列都是文本类型}createTableQuery = createTableQuery.TrimEnd(',') + ");";try{// 创建表using (OleDbCommand createTableCommand = new OleDbCommand(createTableQuery, connection)){createTableCommand.ExecuteNonQuery();}// 插入数据for (int i = 1; i < sheet.Rows.Length; i++) // 跳过第一行{var row = sheet.Rows[i];string insertQuery = $"INSERT INTO [{tableName}] VALUES (";foreach (var cell in row.CellList){insertQuery += $"'{cell.Value?.Replace("'", "''")}',"; // 防止 SQL 注入}insertQuery = insertQuery.TrimEnd(',') + ");";using (OleDbCommand insertCommand = new OleDbCommand(insertQuery, connection)){insertCommand.ExecuteNonQuery();}}}catch (Exception ex){Console.WriteLine($"处理工作表 {sheet.Name} 时发生错误:{ex.Message}");}}connection.Close();workbook.Dispose();}Console.WriteLine("Excel 数据已成功写入新的 Access 数据库!");}}
}
结果

本文介绍如何在.NET平台使用C#导入Excel数据到数据库中。
相关文章:
.NET用C#导入Excel数据到数据库
将Excel文件中的数据导入到数据库中不仅能够提升数据处理的效率和准确性,还能极大地促进数据分析和决策制定的过程。尤其在企业级应用中,Excel作为数据输入和初步整理的工具非常普遍,但其功能对于复杂查询、大规模数据管理和跨部门的数据共享…...
小身躯大能量-供热系统通过EtherCAT转Profinet网关进行升级
在现代工业自动化领域,通信技术的进步对于提高系统效率、稳定性和可靠性起着至关重要的作用。EtherCAT(Ethernet for Control Automation Technology)作为一种实时以太网解决方案,因其高性能及成本效益高等特点,在众多…...
Android11.0系统关闭App所有通知
通过广播接收方式,根据包名关闭App所有通知。 packages/apps/Settings$ git diff diff --git a/AndroidManifest.xml b/AndroidManifest.xml index d4c54c6ed8..1ce7d4136f 100644 --- a/AndroidManifest.xmlb/AndroidManifest.xml-106,6 106,7 <uses-permissio…...
# issue 8 TCP内部原理和UDP编程
TCP 通信三大步骤: 1 三次握手建立连接; 2 开始通信,进行数据交换; 3 四次挥手断开连接; 一、TCP内部原理--三次握手 【第一次握手】套接字A∶"你好,套接字B。我这儿有数据要传给你,建立连接吧。" 【第二次…...
力扣100题--移动零
给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。 请注意 ,必须在不复制数组的情况下原地对数组进行操作。 示例 1: 输入: nums [0,1,0,3,12] 输出: [1,3,12,0,0]示例 2: 输入: nums [0] 输出: […...
Spring 邮件发送
Spring 邮件发送 1. 主要内容(了解) 2. JavaMail 概述(了解) JavaMail,顾名思义,提供给开发者处理电⼦邮件相关的编程接⼝。JavaMail 是由 Sun 定义的⼀套收发电⼦邮件的 API,它可以⽅便地执⾏⼀…...
利用 360 安全卫士极速版关闭电脑开机自启动软件教程
在使用电脑的过程中,过多的开机自启动软件会严重拖慢电脑的开机速度,影响我们的使用体验。本教程中简鹿办公将详细介绍如何使用 360 安全卫士极速版关闭电脑开机自启动软件,让您的电脑开机更加迅速流畅。 一、打开 360 安全卫士极速版 在电…...
楼房销售系统
文末获取源码和万字论文,制作不易,感谢点赞支持。 毕 业 设 计(论 文) 题目:楼房销售系统设计与实现 摘 要 现代经济快节奏发展以及不断完善升级的信息化技术,让传统数据信息的管理升级为软件存储…...
UML箭线图的理解和实践
在软件开发的世界里,UML(统一建模语言)作为一种标准化的建模语言,扮演着举足轻重的角色。UML类图更是软件开发设计和架构过程中的核心工具,它不仅能帮助开发者明确系统中的类及其关系,还能为后续的代码实现…...
Qt入门8——Qt文件
1. Qt文件概述 文件操作是应用程序必不可少的部分。Qt作为⼀个通用开发库,提供了跨平台的文件操作能力。Qt 提供了很多关于文件的类,通过这些类能够对文件系统进行操作,如文件读写、文件信息获取、文件复制或重命名等。 2. 输入输出设备类 在…...
鸿翼受邀出席2024海峡两岸档案暨缩微学术交流会
近日,由中国档案学会、中国文献影像技术协会共同主办,中华档案暨资讯微缩管理学会参加的2024年海峡两岸档案暨缩微学术交流会在乌鲁木齐召开。鸿翼联合创始人兼CTO罗永秀受邀出席本次交流会并作主题分享。 自1992年以来,该学术交流会已连续举…...
支持win7系统的onnxruntime
在win7 X86系统上,使用了onnxruntime.dll库做AI识别,但是在win7上运行报0xc0000005的错误 经查,ONNX Runtime从v1.15.0版本开始不再支持Windows 7及其之前的操作系统,即便尝试重新编译源代码亦无法在这些老系统上运行,…...
如何利用内链策略提升网站的整体权重?
内链是谷歌SEO中常常被低估的部分,实际上,合理的内链策略不仅能帮助提升页面间的关联性,还可以增强网站的整体权重。通过正确的内链布局,用户可以更流畅地浏览你的网站,谷歌爬虫也能更快地抓取到更多页面,有…...
鸿蒙分享(二):引入zrouter路由跳转+封装
码仓库:https://gitee.com/linguanzhong/share_harmonyos 鸿蒙api:12 鸿蒙第三方库地址:OpenHarmony三方库中心仓 zrouter地址:OpenHarmony三方库中心仓 1.引入zrouter 1.打开终端界面:输入 ohpm install hzw/zrouter 2.在项目…...
【计算机网络】实验11:边界网关协议BGP
实验11 边界网关协议BGP 一、实验目的 本次实验旨在验证边界网关协议(BGP)的实际作用,并深入学习在路由器上配置和使用BGP协议的方法。通过实验,我将探索BGP在不同自治系统之间的路由选择和信息交换的功能,理解其在互…...
leetcode 1853 转换日期格式(postgresql)
需求 表: Days ----------------- | Column Name | Type | ----------------- | day | date | ----------------- day 是这个表的主键。 给定一个Days表,请你编写SQL查询语句,将Days表中的每一个日期转化为"day_name, month_name day, year"…...
掌握时间,从`datetime`开始
文章目录 掌握时间,从datetime开始第一部分:背景介绍第二部分:datetime库是什么?第三部分:如何安装这个库?第四部分:简单库函数使用方法1. 获取当前日期和时间2. 创建特定的日期3. 计算两个日期…...
剖析千益畅行,共享旅游-卡,合规运营与技术赋能双驱下的旅游新篇
在数字化浪潮席卷各行各业的当下,旅游产业与共享经济模式深度融合,催生出旅游卡这类新兴产品。然而,市场乱象丛生,诸多打着 “共享” 幌子的旅游卡弊病百出,让从业者与消费者都深陷困扰。今天,咱们聚焦技术…...
集合框架(2)List
Collection的子接口:List、Set 1、List接口 鉴于Java中数组用来存储数据的局限性,我们通常使用java.util.List替代数组List集合类中元素有序、且可重复,集合中的每个元素都有其对应的顺序索引。JDK API中List接口的实现类常用的有ÿ…...
【子查询】.NET开源 ORM 框架 SqlSugar 系列
.NET开源 ORM 框架 SqlSugar 系列 【开篇】.NET开源 ORM 框架 SqlSugar 系列【入门必看】.NET开源 ORM 框架 SqlSugar 系列【实体配置】.NET开源 ORM 框架 SqlSugar 系列【Db First】.NET开源 ORM 框架 SqlSugar 系列【Code First】.NET开源 ORM 框架 SqlSugar 系列【数据事务…...
使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式
一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明:假设每台服务器已…...
设计模式和设计原则回顾
设计模式和设计原则回顾 23种设计模式是设计原则的完美体现,设计原则设计原则是设计模式的理论基石, 设计模式 在经典的设计模式分类中(如《设计模式:可复用面向对象软件的基础》一书中),总共有23种设计模式,分为三大类: 一、创建型模式(5种) 1. 单例模式(Sing…...
stm32G473的flash模式是单bank还是双bank?
今天突然有人stm32G473的flash模式是单bank还是双bank?由于时间太久,我真忘记了。搜搜发现,还真有人和我一样。见下面的链接:https://shequ.stmicroelectronics.cn/forum.php?modviewthread&tid644563 根据STM32G4系列参考手…...
【机器视觉】单目测距——运动结构恢复
ps:图是随便找的,为了凑个封面 前言 在前面对光流法进行进一步改进,希望将2D光流推广至3D场景流时,发现2D转3D过程中存在尺度歧义问题,需要补全摄像头拍摄图像中缺失的深度信息,否则解空间不收敛…...
UR 协作机器人「三剑客」:精密轻量担当(UR7e)、全能协作主力(UR12e)、重型任务专家(UR15)
UR协作机器人正以其卓越性能在现代制造业自动化中扮演重要角色。UR7e、UR12e和UR15通过创新技术和精准设计满足了不同行业的多样化需求。其中,UR15以其速度、精度及人工智能准备能力成为自动化领域的重要突破。UR7e和UR12e则在负载规格和市场定位上不断优化…...
CMake控制VS2022项目文件分组
我们可以通过 CMake 控制源文件的组织结构,使它们在 VS 解决方案资源管理器中以“组”(Filter)的形式进行分类展示。 🎯 目标 通过 CMake 脚本将 .cpp、.h 等源文件分组显示在 Visual Studio 2022 的解决方案资源管理器中。 ✅ 支持的方法汇总(共4种) 方法描述是否推荐…...
算法笔记2
1.字符串拼接最好用StringBuilder,不用String 2.创建List<>类型的数组并创建内存 List arr[] new ArrayList[26]; Arrays.setAll(arr, i -> new ArrayList<>()); 3.去掉首尾空格...
R 语言科研绘图第 55 期 --- 网络图-聚类
在发表科研论文的过程中,科研绘图是必不可少的,一张好看的图形会是文章很大的加分项。 为了便于使用,本系列文章介绍的所有绘图都已收录到了 sciRplot 项目中,获取方式: R 语言科研绘图模板 --- sciRplothttps://mp.…...
实战三:开发网页端界面完成黑白视频转为彩色视频
一、需求描述 设计一个简单的视频上色应用,用户可以通过网页界面上传黑白视频,系统会自动将其转换为彩色视频。整个过程对用户来说非常简单直观,不需要了解技术细节。 效果图 二、实现思路 总体思路: 用户通过Gradio界面上…...
9-Oracle 23 ai Vector Search 特性 知识准备
很多小伙伴是不是参加了 免费认证课程(限时至2025/5/15) Oracle AI Vector Search 1Z0-184-25考试,都顺利拿到certified了没。 各行各业的AI 大模型的到来,传统的数据库中的SQL还能不能打,结构化和非结构的话数据如何和…...
