当前位置: 首页 > news >正文

c# 将excel导入 sqlite

nuget 须要加载
EPPlus.Core
ExcelDataReader
ExcelDataReader.DataSet

//需要引用的扩展
using ExcelDataReader;
using ExcelPackage = OfficeOpenXml.ExcelPackage;
public static void CreateZhouPianChaTable(){string tbname = "zhou_pian_cha1";//判断表是否存在bool isExist = TableIsExist(tbname);if (!isExist){SQLiteConnection db = ConnectToDatabase(SqLite1);_sql = $"create table {tbname} ( ID integer NOT NULL PRIMARY KEY AUTOINCREMENT,size_min real(255),size_max real(255),tolerance_class Text(255),ES real(255),El real(255) )";_command = new SQLiteCommand(_sql, db);_command.ExecuteNonQuery();string excelFilePath = @"D:\c#\轴的极限偏差.xlsx";//另外一种将excel 读取到 datatable 的方式// using (ExcelPackage package = new ExcelPackage(new FileInfo(excelFilePath))) {//     ExcelWorksheet worksheet = package.Workbook.Worksheets[1];//     //     // 读取数据到 DataTable 中//     DataTable dataTable = new DataTable(worksheet.Name);//     foreach (var firstRowCell in worksheet.Cells[1, 1, 1, worksheet.Dimension.End.Column]) {//         dataTable.Columns.Add(firstRowCell.Text);//     }//     for (int rowNumber = 2; rowNumber <= worksheet.Dimension.End.Row; rowNumber++) {//         var row = worksheet.Cells[rowNumber, 1, rowNumber, worksheet.Dimension.End.Column];//         DataRow dr = dataTable.Rows.Add();//         foreach (var cell in row) {//             dr[cell.Start.Column - 1] = cell.Text;//         }//     }//     // }var data = ReadExcelToDataSet(excelFilePath);DataTable dataTable = data.Tables[0];string addsql = $"INSERT INTO {tbname} (ID, size_min, size_max,tolerance_class,ES,El) VALUES (@Column1, @Column2, @Column3,@Column4,@Column5,@Column6)";// 插入数据using (var bulkInsertCommand = new SQLiteCommand(addsql, db)){bulkInsertCommand.Parameters.AddWithValue("@Column1", dataTable.Rows[0][0]);bulkInsertCommand.Parameters.AddWithValue("@Column2", dataTable.Rows[0][1]);bulkInsertCommand.Parameters.AddWithValue("@Column3", dataTable.Rows[0][2]);bulkInsertCommand.Parameters.AddWithValue("@Column4", dataTable.Rows[0][3]);bulkInsertCommand.Parameters.AddWithValue("@Column5", dataTable.Rows[0][4]);bulkInsertCommand.Parameters.AddWithValue("@Column6", dataTable.Rows[0][5]);for (int i = 1; i < dataTable.Rows.Count; i++){bulkInsertCommand.Parameters["@Column1"].Value = dataTable.Rows[i][0];bulkInsertCommand.Parameters["@Column2"].Value = dataTable.Rows[i][1];bulkInsertCommand.Parameters["@Column3"].Value = dataTable.Rows[i][2];bulkInsertCommand.Parameters["@Column4"].Value = dataTable.Rows[i][3];bulkInsertCommand.Parameters["@Column5"].Value = dataTable.Rows[i][4];bulkInsertCommand.Parameters["@Column6"].Value = dataTable.Rows[i][5];bulkInsertCommand.ExecuteNonQuery();}}db.Close();}}/// <summary>/// 判断数据表是否存在/// </summary>/// <param name="tableName"></param>/// <returns></returns>public static bool TableIsExist(String tableName){try{SQLiteConnection db = ConnectToDatabase(SqLite1);using (SQLiteCommand cmd = db.CreateCommand()){cmd.CommandText = "SELECT count(*) from sqlite_master where type='table' and name='" + tableName +"'; ";if (Convert.ToInt32(cmd.ExecuteScalar()) == 0) // 不存在此数据表{return false;}else //存在此数据表,直接加数据{return true;}}}catch{// ignored}return false;}//创建一个连接到指定数据库public static SQLiteConnection ConnectToDatabase(string dbName){_mDbConnection = new SQLiteConnection($"Data Source={dbName}.db;Version=3;"); //没有数据库则自动创建_mDbConnection.Open();return _mDbConnection;}//读取excelpublic static DataSet ReadExcelToDataSet(string fileNmaePath){FileStream stream = null;IExcelDataReader excelReader = null;DataSet dataSet = null;try{//stream = File.Open(fileNmaePath, FileMode.Open, FileAccess.Read);stream = new FileStream(fileNmaePath, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);}catch{MessageBox.Show("无法读取文件.");return null;}string extension = Path.GetExtension(fileNmaePath);if (extension.ToUpper() == ".XLS"){excelReader = ExcelReaderFactory.CreateBinaryReader(stream);}else if (extension.ToUpper() == ".XLSX"){excelReader = ExcelReaderFactory.CreateOpenXmlReader(stream);}else{MessageBox.Show("格式错误.");return null;}dataSet = excelReader.AsDataSet();//第一行当作数据读取excelReader.Close();return dataSet;}
http://www.lryc.cn/news/226684.html

相关文章:

  • KafkaConsumer 消费逻辑
  • scss 实用教程
  • NO.304 二维区域和检索 - 矩阵不可变
  • 牛客---简单密码python
  • devops完整搭建教程(gitlab、jenkins、harbor、docker)
  • 页面上时间显示为数字 后端返回给前端 response java系统
  • idea怎么配置tomcat
  • GoLong的学习之路(二十三)进阶,语法之并发(go最重要的特点)(锁,sync包,原子操作)
  • asp.net core 生命周期
  • Leetcode刷题详解—— 目标和
  • 学习c#的第六天
  • 第七章 :Spring Boot web开发常用注解(二)
  • IOC - Google Guice
  • 国际阿里云:Linux实例负载高问题排查和异常处理!!!
  • 【数据结构】二叉树的遍历递归算法详解
  • 百度王颖:百度文库以AI创作能力突破语言边界,促进思想碰撞和文化融通
  • 人工智能基础_机器学习023_理解套索回归_认识L1正则---人工智能工作笔记0063
  • Learning an Animatable Detailed 3D Face Model from In-The-Wild Images论文笔记
  • Lenovo联想小新Air-14笔记本2021款AMD锐龙ALC版(82LM)原装出厂Win10镜像和Windows11预装OEM系统
  • 在程序中链接静态库
  • TortoiseSVN 状态图标不显示的两种解决办法
  • NSSCTF-Crypto入门题 练习记录贴 ‘‘一‘‘
  • Day03:注意事项、this关键字、构造器、JavaBean、String、ArrayList
  • 【从0到1设计一个网关】性能优化---缓存
  • Typescript -尚硅谷
  • 以 Kubernetes 原生方式实现多集群告警
  • 2023年A股借壳上市研究报告
  • 【TiDB】TiDB CLuster部署
  • odoo16 库存初始化 excel导入问题
  • 2023.11.11 关于 Spring 中 Bean 的作用域